当前位置: 首页 > news >正文

【文字三国志:第四篇】天命重构,后端 API 设计文档

第一章:整体架构

1.1 设计理念

本项目的后端 API 采用Next.js 13 App RouterRoute Handlers能力构建。你可以把它理解为:每个 API 端点都是一个独立的“小服务”,它们共同组成了一个完整的游戏后端。

所有业务接口都统一放在/api/game这个“大门”下,这样做的好处是:

  • 路径清晰:一眼就能看出这是游戏相关的功能
  • 便于管理:相关的功能模块集中存放
  • 易于扩展:新增功能只需在game下新建目录

1.2 技术架构图

HTTP Request

验证通过

验证失败

参数校验

校验失败

校验通过

读取操作

命中

未命中

写入操作

完成后

SSE事件

数据

统一格式

客户端

鉴权中间件

Route Handlers
src/app/api/game/*/route.ts

返回401错误

Zod Schema

返回400错误

业务处理层

LRU缓存

返回结果

Prisma + PostgreSQL

事务保证

实时推送

1.3 目录结构说明

src/app/api/game/ ├── start/ # 游戏初始化 │ └── route.ts ├── action/ # 玩家动作 │ └── route.ts ├── combat/ # 战斗日志 │ └── route.ts ├── achievements/ # 成就系统 │ └── route.ts ├── alliances/ # 联盟系统 │ └── route.ts ├── policy/ # 政策系统 │ └── route.ts └── events/ # 实时事件 └── route.ts

每个route.ts文件都保持精简,只做三件事:校验身份 → 校验参数 → 调用核心逻辑


第二章:通用约定规范

2.1 HTTP 方法使用规范

方法使用场景示例
GET查询数据,不改变服务器状态查询联盟列表、获取政策详情
POST创建资源或触发动作提交战斗指令、解锁成就
PUT/PATCH更新现有资源修改玩家配置
DELETE删除资源退出联盟(少数情况)

2.2 统一的返回格式

所有的 API 都遵循相同的“包装格式”,就像快递包裹一样:

// 成功时{success:true,data:{/* 具体的业务数据 */}}// 失败时{success:false,error:"具体的错误信息"}

2.3 鉴权机制

验证服务API Gateway客户端验证服务API Gateway客户端
http://www.zskr.cn/news/1425142.html

相关文章:

  • 别再纠结驱动了!Java直连网络打印机(IP+端口9100)打印PDF保姆级教程
  • 游戏开发实战:用SAT算法搞定Unity/Unreal中复杂3D模型的碰撞检测(附C++/C#代码)
  • TVA 对 CV 的代际超越逻辑(10)
  • 手把手教你逆向拼多多H5/Temu的anti_content参数(附完整JavaScript代码)
  • 告别复杂参数!用Fooocus的‘Style’和‘Negative Prompt’快速生成高质量AI图片
  • UE5.1+ControlRig避坑实录:从创建控制器到驱动骨骼,新手最常遇到的3个报错及解决方法
  • 从依赖报错到完美汉化:在Ubuntu 20.04/22.04上安装配置Beyond Compare 4的完整避坑记录
  • 用Python+遗传算法搞定物流配送路线规划:一个外卖小哥的实战代码分享
  • 2026年4月加注装置品牌找哪家,移动式加油站/LNG撬装加气装置/撬装加油装置/船舶甲醇燃料加注站,加注装置厂家选哪家 - 品牌推荐师
  • 用STM32CubeMx和DMA搞定WS2812B灯带:从单灯测试到彩虹流水灯实战(附完整代码)
  • 告别蓝屏!手把手教你给NVMe固态硬盘装Win7(附驱动整合U盘制作)
  • 从FPU到SSE:x86汇编浮点计算演进与性能调优浅谈
  • 告别护眼APP:手把手教你为Android系统(AOSP 11)添加原生全局色温调节功能
  • 从Demo到集成:手把手教你用Vue项目测试OnlyOffice 7.4破解后的协作编辑功能
  • ESP32-C3安全启动与Flash加密实战:绕过自动重启,一步到位配置Secure Boot V2
  • ESP32-C3的Secure Boot与Flash加密避坑指南:从menuconfig配置到efuse烧录的完整排错记录
  • 华为海思HI3798MV310芯片盒子刷机避坑指南:TTL接线、HiTool设置与固件选择
  • Windows 10/11 也能有 Mac 的丝滑体验?手把手教你用 MyDockFinder 打造高颜值桌面(附运行库避坑指南)
  • 从运放到LDO:手把手分析电压-电压反馈(V-V)在实际电路中的开环增益与稳定性
  • 别再只做温度计了!用STC89C52和DS18B20,我这样做出了一个智能温控小系统
  • Cadence 617实战:手把手教你搞定一个零温漂的Bandgap基准源(附仿真文件)
  • 保姆级教程:用Signac搞定小鼠脑单细胞ATAC数据的TF motif富集分析(附避坑指南)
  • 新手必看:埃夫特ER3B-C60机器人维护保养,从示教器登录到关节调零的保姆级流程
  • 从一张GCViewer图表说起:如何快速定位线上服务的频繁Full GC问题?
  • 用Python递归解决‘聪明士兵’问题:从CSDN题解到面试常考算法实战
  • 保姆级避坑指南:用Kalibr搞定ZED 2双目相机与IMU联合标定,跑通VINS-Fusion
  • DrissionPage元素查找全攻略:从CSS选择器到XPath,一篇搞定所有定位姿势
  • 避坑指南:QEMU安装银河麒麟V10SP1时,你可能会遇到的5个典型错误及解决方法
  • 2026年5月北海黄金回收机构实测评测对比 - 优质品牌商家
  • Unity手游开发避坑:90Hz安卓机锁45帧?手把手教你用Surface.setFrameRate()强制60帧