@ExceptionHandler
定义在方法上标记该方法为异常方法,触发异常并执行
Exceptions handled by the annotated method. If empty, will default to any
exceptions listed in the method argument list.(由批注方法处理的异常。如果为空,则默认为方法参数列表中列出的任何异常.)
需要注意的是这个注解的处理范围只有当前类的局部。只会处理当前类的异常。
@Controller
public class GoodsController {
@GetMapping("/goods")
public String goods(){
int x = 3/0;
return "goods";
}
@ExceptionHandler
public ModelAndView modelAndView(Exception e){
ModelAndView mv = new ModelAndView();
mv.addObject("error",e.getMessage());
mv.setViewName("goods");
return mv;
}
}
@ControllerAdvice
这个注解是定义在类上的,标注当前类为异常处理控制类,被标记之后,只有全局内有异常,都会在这个类中进行处理。
这样的话,我们就可以联想到这两个注解搭配使用。
@Data
@AllArgsConstructor
@NoArgsConstructor
public class ResultBean {
int code;
String msg;
Object date;
}
/**
* 封装一下返回值
*/
public abstract class BeanController {
private final int SUCCESS=200;
private final int FAIL=0;
protected ResultBean success(String msg){
return convert(SUCCESS,msg,null);
}
protected ResultBean success(String msg,Object data){
return convert(SUCCESS,msg,data);
}
protected ResultBean fail(String msg){
return convert(FAIL,msg,null);
}
protected ResultBean fail(String msg,Object data){
return convert(FAIL,msg,data);
}
/**
* 封装一下ResultBean
* @param code
* @param msg
* @param data
* @return
*/
ResultBean convert(int code,String msg,Object data){
return new ResultBean(code,msg,data);
}
}
异常处理类
@ControllerAdvice//标记异常处理类
@ResponseBody // 响应并转换为json
public class GlobalExceptionHandler extends BeanController {
/**
* 指定异常处理
* @param e
* @return
*/
@ExceptionHandler(value = {NullPointerException.class})
public ResultBean ex(Exception e){
return fail("空指针异常",e.getMessage());
}
/**
* 全部异常都会进行处理
* @param e
* @return
*/
@ExceptionHandler
public ResultBean sex(Exception e){
return fail("内部服务器错误消息:",e.getMessage());
}
}