Java后端接口返回结构统一的核心是定义通用响应体Result,包含code、message、data三要素,并通过全局异常处理和统一返回拦截强制应用。
Java后端接口返回结构统一,核心是定义一个通用的响应体(如 Result),配合状态码、消息、数据三要素,并在全局异常处理和统一返回拦截中强制应用。
这是整个规范的基石。建议包含以下字段:
提供常用静态构造方法,例如:success(data)、fail(code, msg)、badRequest(msg),让 Controller 层调用简洁直观。
所有 @RestController 接口方法的返回值类型必须声明为 Result、Result 等,禁止直接返回 POJO、Map 或 void。>
这样做的好处:
dvice + ResponseEntity 实现全局统一封装避免每个接口手动 new Result,推荐通过全局返回处理器自动包装:
@RestControllerAdvice 类,拦截所有 @ResponseBody 方法的返回值beforeBodyWrite 方法,对非 Result 类型的返回值自动封装为 Result.success(value)
注意:需排除异常情况(由统一异常处理器单独处理),确保业务正常返回和异常返回两条路径清晰分离。
所有运行时异常(如参数校验失败、业务规则拒绝、数据库异常)不应透出堆栈,而应转换为标准 Result:
@ExceptionHandler 捕获 MethodArgumentNotValidException,提取校验错误并返回 Result.fail(400, "用户名不能为空")
UserNotExistException)继承 RuntimeException,并在异常处理器中映射到对应 code/messageResult.fail(500, "系统繁忙,请稍后再试")
确保无论什么错误,前端收到的永远是 { "code":xxx, "message":"xxx", "data":null } 结构。
不复杂但容易忽略的是:团队需约定好 code 范围划分(如 1xx 业务码、4xx 客户端错误、5xx 服务端错误),并在文档或枚举类中固化,避免各模块随意定义导致前端难以维护。