1.通用返回response
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
/**
* 通用返回response
*/
@Data
@AllArgsConstructor
@NoArgsConstructor
public class BaseResponse {
private Integer code;
private String message;
}
用到lombok的几个基本注解:@Data@AllArgsConstructor@NoArgsConstructor
@Data
使用这个注解,就不用再去手写Getter,Setter,equals,canEqual,hasCode,toString等方法了,注解后在编译时会自动加进去。
@AllArgsConstructor
使用后添加一个构造函数,该构造函数含有所有已声明字段属性参数
@NoArgsConstructor
使用后创建一个无参构造函数
2.统一异常处理 异常父类
import lombok.Data;
/**
* 统一异常处理 异常父类
* lulin 2019年5月22日10:09:00
*/
@Data
public class DemoException extends RuntimeException {
private Integer code;
private String message;
public DemoException(Integer code,String message){
this.code = code;
this.message = message;
}
}
3.拦截异常并统一处理
/**
* 拦截异常并统一处理
* @ControllerAdvice用于定义@ExceptionHandler、@InitBinder、@ModelAttribute,并应用到所有@RequestMapping中
* lulin
* 2019年5月22日10:48:35
*/
@Slf4j
@ControllerAdvice
public class GlobalExceptionHandler {
/**
* 全局异常捕捉处理
* @param ex
* @return
*/
@ResponseBody
@ExceptionHandler(value = Exception.class)
public Map errorHandler(Exception ex) {
Map map = new HashMap();
map.put("code", 100);
map.put("message", ex.getMessage());
return map;
}
/**
* 拦截捕捉自定义异常 DemoException.class
* @param ex
* @return
*/
@ResponseBody
@ExceptionHandler(value = DemoException.class)
public Map myErrorHandler(DemoException ex) {
Map map = new HashMap();
map.put("code", ex.getCode());
map.put("message", ex.getMessage());
return map;
}
}
用到了注解@ControllerAdvice。可以用于定义@ExceptionHandler、@InitBinder、@ModelAttribute,并应用到所有@RequestMapping中。这里主要用到@ExceptionHandler注解,全局异常捕捉处理。
4.controller中抛出异常进行测试
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class DemoController {
@GetMapping("/exception")
public BaseResponse testException() {
if (System.currentTimeMillis() % 2 != 0) {
throw new DemoException(301, "产生了自定义错误");
}
return new BaseResponse(200, "没有错误");
}
}
测试结果