天天看点

14.全局异常处理

1.全局异常简介

Web应用请求处理过程中时常会发生异常,当发生异常时,需要通过一个统一的异常处理来保证客户端能够收到友好的提示。

2.全局异常类开发

复制一份“集成MyBatis”的项目代码,修改项目名称为globalexception。然后在项目目录“/src/main/java/com/leichuangkj/globalexception/common”下新建GlobalExceptionHandler类,具体代码如下。

@ControllerAdvice
public class GlobalExceptionHandler {
    private static final org.slf4j.Logger logger = LoggerFactory.getLogger(GlobalExceptionHandler.class);
    @ExceptionHandler(value = Exception.class)
    @ResponseBody
    public ServerResponse errorHandler(HttpServletRequest req, Exception e) throws Exception {
        logger.error("{} exception",req.getRequestURI(),e);
        return ServerResponse.createByErrorCodeMessageData(ResponseCode.ERROR.getCode(),"接口异常,详情请查看服务端日志!",e.toString());
    }
}      
  • @ControllerAdvice:定义统一的异常类,可通过basepackages属性自定义需要扫描的包。
  • @ExceptionHandler:定义函数的异常类型,可传入多个需要捕获的异常类。
  • @ResponseBody:返回json格式的数据。

3.在UserController类中添加会产生异常的代码

@Controller
@RequestMapping("/user")
public class UserController {
    @Autowired
    UserImpl userImpl;

    @RequestMapping(value = "/findByName",method = RequestMethod.POST)
    @ResponseBody
    public ServerResponse findByName(@RequestBody User user){
        int rs = 1/0;
        return userImpl.findByName(user.getName());
    }
}      

4.启动项目

在启动类GlobalexceptionApplication上添加注解“@MapperScan(basePackages = “com.leichuangkj.globalexception.dao.mapper”)”,然后启动项目。

@MapperScan(basePackages = "com.leichuangkj.globalexception.dao.mapper")
@SpringBootApplication
public class GlobalexceptionApplication {
  public static void main(String[] args) {
    SpringApplication.run(GlobalexceptionApplication.class, args);
  }
}      

5.测试

启动项目,然后在postman中请求“http://localhost:8080/user/findByName”,可以查询到相应的信息,测试结果如下图所示。

14.全局异常处理