- 正常返回
applicaiton/json
格式进行返回数据data
具体的业务数据http status code
为200traceId
为唯一的请求id
- 业务逻辑异常,为了统一返回的数据结构,统一使用了zalando/problem项目作为返回的数据结构。主要包括:
- 定义统一的业务异常类,然后统一捕获该异常类,然后转换数据结构。
applicaiton/json
格式进行返回数据detail
为对应的错误信息简单描述code
为对应的业务错误码type
为异常请求的urihttp status code
为200traceId
为唯一的请求id
- 请求异常,统一识别异常类型,然后转换数据结构
applicaiton/json
格式进行返回数据detail
为对应的错误信息简单描述code
为对应的业务错误码type
为异常请求的urihttp status code
为400、401、403、404、405、406、415traceId
为唯一的请求id
- 非业务异常类,统一处理
applicaiton/json
格式进行返回数据detail
为对应的错误信息简单描述code
为对应的错误码type
为异常请求的urihttp status code
为500、501traceId
为唯一的请求id
- 通过继承zalando/problem-spring-web项目的
ProblemHandling
类 - 通过使用
@RestControllerAdvice
来统一捕获异常 - 额外定义业务异常类的统一处理方法
- 通过使用
ResponseBodyAdvice
接口和@RestControllerAdvice
来统一添加traceId和请求的uri