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

如何设计一个优秀的接口?统一结果返回值

文章目录

  • ✨ 一、接口的统一返回值是什么?
  • ✨ 二、为什么要统一返回值?
  • ✨ 三、怎么做?(带代码实现)
      • 1. 先定义统一返回体 ResponseResult
      • 2. 在Controller层中用
      • 3. 全局异常统一放回

✨ 一、接口的统一返回值是什么?

它是一件外套,把所有接口的返回内容装进同一套格式里。无论请求成功还是出错,都给前端返回固定结构,比如:

{"code":200,"message":"OK","data":{...}}

像讲故事时总是用“开头、正文、结尾”一样,你的接口也需要固定的句式,让对方不用猜今天你会不会突然换腔调。

常见结构会包含:

  • code业务状态码(不是 HTTP 状态码)

  • message提示信息(成功/失败原因)

  • data业务数据

  • timestamp(可选)响应时间

  • traceId(可选)链路追踪辅助

🎐 这让你的接口像带格式的礼物盒,不会乱七八糟。


✨ 二、为什么要统一返回值?

这一段像在写接口的“生存理由”:

  1. 前端更好处理
    前端只需要写一套判断逻辑,比如code === 200 OK。如果每个接口都长得不一样,前端会像解一个拼不出来的拼图。

  2. 调试更舒服
    报错结构一致,日志里查问题一眼看穿。

  3. 团队协作不会混乱
    新人写接口也不用再纠结“到底怎么返回”。

  4. 更适合大项目/中台
    各个服务统一语言,像所有人都用同一个字典。

  5. 可以扩展功能
    比如自动加 traceId、自动包装异常、全局异常处理等等,统一返回是基础。


✨ 三、怎么做?(带代码实现)

这一步像搭一座小桥,把规范送到所有接口上。


1. 先定义统一返回体 ResponseResult

@DatapublicclassR<T>{privateIntegercode;privateStringmessage;privateTdata;publicstatic<T>R<T>success(Tdata){R<T>r=newR<>();r.setCode(200);r.setMessage("success");r.setData(data);returnr;}publicstatic<T>R<T>fail(Stringmessage){R<T>r=newR<>();r.setCode(500);r.setMessage(message);returnr;}}

2. 在Controller层中用

@GetMapping("/user/{id}")publicR<User>getUser(@PathVariableLongid){Useruser=userService.getById(id);returnR.success(user);}

3. 全局异常统一放回

@RestControllerAdvicepublicclassGlobalExceptionHandler{@ExceptionHandler(Exception.class)publicRhandleException(Exceptione){returnR.fail(e.getMessage());}}
http://www.jsqmd.com/news/74010/

相关文章:

  • LVGL9.5 设置背景图片的方法
  • BetterGI:原神智能辅助工具终极使用指南
  • 多模态大模型技术突破:Qwen3-VL全系列深度解析与本地化部署指南
  • Wan2.2-T2V-A14B如何实现服装材质的真实感渲染?
  • 校运会管理系统(11447)
  • Qwen-Image-Edit-Rapid-AIO全版本解析:从多模态融合到专业化模型演进之路
  • 基于图像处理的海洋生物海鲜识别算法设计
  • 地平线首届技术生态大会擘画智驾产业新范式
  • 20轴足球魔方
  • 入门友好的低代码平台推荐,其中一款完全免费又能私有化部署
  • 基于PSOBP_NSGA2_Topsis粒子群算法优化BP做代理预测模型目标遗传NSGA2和Topsis求最优解研究(Matlab代码实现)
  • 基于VUE的小剧场票务系统[VUE]-计算机毕业设计源码+LW文档
  • html表格
  • Wan2.2-T2V-A14B如何应对多光源混合照明场景生成
  • Wan2.2-T2V-A14B如何生成带有购物车结算流程的电商导购视频?
  • Wan2.2-T2V-A14B物理模拟能力详解:让动作更自然真实
  • Wan2.2-T2V-A14B在实时视频生成方向的技术展望
  • Wan2.2-T2V-A14B支持720P输出对移动端适配的意义
  • 视频转文字工具文章创作Prompt
  • 阿里Qwen3双模型震撼开源:嵌入式与重排序技术革新RAG应用生态
  • 孤能子视角:人工智能逻辑因果模型的孤能子理论
  • Blender 3MF插件终极使用指南:从安装到故障排查全流程解析
  • 大模型应用开发(十四)_LangChain 多轮对话
  • 走进Python的高级世界,你不知道的几个Python技巧
  • 如何快速实现Unity游戏翻译:XUnity.AutoTranslator终极指南
  • 轻量化AI新纪元:Smol Vision引领视觉模型高效部署革命
  • Wan2.2-T2V-A14B如何实现人物行走动作的自然流畅
  • Wan2.2-T2V-A14B模型API接口设计与调用示例详解
  • 打造基于C++、Qt与OpenCV的超酷图像编辑器
  • MiniCPM-Llama3-V 2.5 int4:轻量级多模态模型部署新选择,显存占用低至9GB