编辑
2023-03-13
实用工具
00
请注意,本文编写于 752 天前,最后修改于 517 天前,其中某些信息可能已经过时。

目录

搭建新的项目时都需要设置统一的响应类(Result)
首先设置一个枚举类Enum
设置一个响应的包装类
业务异常类
全局异常处理
统一处理返回值
使用

搭建新的项目时都需要设置统一的响应类(Result)

首先设置一个枚举类Enum

放置常用的一些响应信息

java
public enum ResultCodeEnum { ERROR(100, "系统错误"), SUCCESS(200, "操作成功"), FAILED(500, "操作失败"); VALIDATE_FAILED(404, "参数检验失败"), UNAUTHORIZED(401, "暂未登录或token已经过期"), FORBIDDEN(403, "没有相关权限"); // 自定义状态码 private final int code; // 自定义描述 private final String msg; ReturnCode(int code, String msg){ this.code = code; this.msg = msg; } public int getCode() { return code; } public String getMsg() { return msg; } }

设置一个响应的包装类 包含一些响应状态码、响应消息、响应数据、接口请求时间等

java
public class CommonResult<T> { private long code; private String message; private T data; protected CommonResult() { } protected CommonResult(long code, String message, T data) { this.code = code; this.message = message; this.data = data; } /** * 成功返回结果 * * @param data 获取的数据 */ public static <T> CommonResult<T> success(T data) { return new CommonResult<T>(ResultCodeEnum.SUCCESS.getCode(), ResultCodeEnum.SUCCESS.getMessage(), data); } /** * 成功返回结果 * * @param data 获取的数据 * @param message 提示信息 */ public static <T> CommonResult<T> success(T data, String message) { return new CommonResult<T>(ResultCodeEnum.SUCCESS.getCode(), message, data); } /** * 失败返回结果 * @param errorCode 错误码 */ public static <T> CommonResult<T> failed(IErrorCode errorCode) { return new CommonResult<T>(errorCode.getCode(), errorCode.getMessage(), null); } /** * 失败返回结果 * @param message 提示信息 */ public static <T> CommonResult<T> failed(String message) { return new CommonResult<T>(ResultCodeEnum.FAILED.getCode(), message, null); } /** * 失败返回结果 */ public static <T> CommonResult<T> failed() { return failed(ResultCodeEnum.FAILED); } /** * 参数验证失败返回结果 */ public static <T> CommonResult<T> validateFailed() { return failed(ResultCodeEnum.VALIDATE_FAILED); } /** * 参数验证失败返回结果 * @param message 提示信息 */ public static <T> CommonResult<T> validateFailed(String message) { return new CommonResult<T>(ResultCodeEnum.VALIDATE_FAILED.getCode(), message, null); } /** * 未登录返回结果 */ public static <T> CommonResult<T> unauthorized(T data) { return new CommonResult<T>(ResultCodeEnum.UNAUTHORIZED.getCode(), ResultCodeEnum.UNAUTHORIZED.getMessage(), data); } /** * 未授权返回结果 */ public static <T> CommonResult<T> forbidden(T data) { return new CommonResult<T>(ResultCodeEnum.FORBIDDEN.getCode(), ResultCodeEnum.FORBIDDEN.getMessage(), data); } public long getCode() { return code; } public void setCode(long code) { this.code = code; } public String getMessage() { return message; } public void setMessage(String message) { this.message = message; } public T getData() { return data; } public void setData(T data) { this.data = data; } }

业务异常类

java
/** * 描述:通用业务异常 * @author lhw * */ @Data @EqualsAndHashCode(callSuper = true) public class BusinessException extends RuntimeException{ /** * 异常编码 */ private String code; /** * 通过枚举类创建异常对象 * @param resultCodeEnum 枚举类 */ public BusinessException(ResultCodeEnum resultCodeEnum) { super(resultCodeEnum.getMessage()); this.code = resultCodeEnum.getCode(); } /** * 通过状态码和错误消息创建异常对象 * @param code 状态码 * @param message 错误消息 */ public BusinessException(String code, String message) { super(message); this.code = code; } }

全局异常处理

java
@Slf4j @RestControllerAdvice public class GlobalExceptionHandler { /** * 处理请求参数校验错误:针对@RequestBody使用@Valid注解校验 * @param e 校验失败异常 * @param request request请求类 * @return 全局统一返回结果类 */ @ExceptionHandler(MethodArgumentNotValidException.class) public Result<String> handler(HttpServletRequest request, MethodArgumentNotValidException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); String message = e.getBindingResult().getAllErrors().stream().map( DefaultMessageSourceResolvable::getDefaultMessage).collect(Collectors.joining(",")); return Result.fail(ResultCodeEnum.ERR_0x1001.getCode(), message); } /** * 处理请求参数校验错误:单个参数校验异常抛出,针对@RequestParam上增加校验注解,并在类上标注@Validated * @param request request请求类 * @param e 校验失败异常 * @return 全局统一返回结果类 */ @ExceptionHandler(ConstraintViolationException.class) public Result<String> handler(HttpServletRequest request, ConstraintViolationException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); String message = e.getConstraintViolations().stream().map( ConstraintViolation::getMessage).collect(Collectors.joining(",")); return Result.fail(ResultCodeEnum.ERR_0x1001.getCode(), message); } /** * 处理请求参数校验错误:针对表单类型的提交,即使用form data方式调用接口,进行参数校验错误时会抛出BindException异常 * @param request request请求类 * @param e 校验失败异常 * @return 全局统一返回结果类 */ @ExceptionHandler(BindException.class) public Result<String> handler(HttpServletRequest request, BindException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); return Result.fail(ResultCodeEnum.ERR_0x1001.getCode(), Objects .requireNonNull(e.getBindingResult().getFieldError()).getDefaultMessage()); } /** * 绑定参数异常:如必须参数没传递 * @param request request请求类 * @param e 校验失败异常 * @return 全局统一返回结果类 */ @ExceptionHandler(ServletRequestBindingException.class) public Result<String> handler(HttpServletRequest request, ServletRequestBindingException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); return Result.fail(ResultCodeEnum.ERR_0x1002); } @ExceptionHandler(HttpRequestMethodNotSupportedException.class) public Result<String> handler(HttpServletRequest request, HttpRequestMethodNotSupportedException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); return Result.fail(ResultCodeEnum.ERR_0x1003); } @ExceptionHandler(BusinessException.class) public Result<String> handler(HttpServletRequest request, BusinessException e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); return Result.fail(e.getCode(), e.getMessage()); } /** * 其他异常处理 * @param request request请求类 * @param e 异常 * @return 全局统一返回结果类 */ @ExceptionHandler(Exception.class) public Result<String> handler(HttpServletRequest request, Exception e) { log.error("[全局统一异常处理]:异常URL:{},Message:{}", request.getRequestURL().toString(), e.getMessage(), e); return Result.fail(ResultCodeEnum.ERR_0x1000.getCode(),e.getMessage()); } }

统一处理返回值

java
/** * 描述:拦截Controller方法的返回值,统一处理返回值/响应体 */ @RestControllerAdvice(basePackages = {"com.lhw.controller"}) public class ResultAdvice implements ResponseBodyAdvice<Object> { @Autowired private ObjectMapper objectMapper; @Override public boolean supports(MethodParameter methodParameter, Class<? extends HttpMessageConverter<?>> aClass) { return true; } @SneakyThrows @Override public Object beforeBodyWrite(Object o, MethodParameter methodParameter, MediaType mediaType, Class<? extends HttpMessageConverter<?>> aClass, ServerHttpRequest serverHttpRequest, ServerHttpResponse serverHttpResponse) { if(o instanceof String){ return objectMapper.writeValueAsString(Result.success(o)); } if(o instanceof Result){ return o; } return Result.success(o); } }

使用

java
@GetMapping public Result<IPage<User>> selectAll(Page<User> page, User user) { return Result.success(this.userService.page(page, new QueryWrapper<>(user))); }

错误的话就抛出 Result.fail();

或者填入一些自定义的状态码和响应消息

本文作者:Weee

本文链接:

版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!