背景
在 Web 开发中, 我们经常会需要处理各种异常, 这是一件棘手的事情, 需要考虑以下几个问题 :
- 什么时候需要捕获 ( try-catch ) 异常, 什么时候需要抛出 ( throws ) 异常到上层 ?
- 在 dao 层捕获还是在 service 捕获, 还是在 controller 层捕获 ?
- 抛出异常后要怎么处理. 怎么返回给页面错误信息 ?
全局异常处理
推荐做法
不要在业务代码中进行捕获异常
,即 dao, service, controller 层的所有异常都全部抛出到上层
. 这样不会导致业务代码中的一堆 try-catch 导致业务代码混乱.哪一层都不捕获
.返回统一的结果集 ( 错误码 + 错误描述 )
.
通常会将事务配置在 Service 层
, 当数据库操作失败时, 让 Service 层抛出运行时异常, 而不进行 try-catch 处理, Spring 事物管理器就会进行回滚. 为了事务回滚
但 Service 层抛出后. 在 Controller 层就需要 try-catch 去捕获异常, 否则会返回原生错误信息到客户端. 但是, 如果在 Controller 层的每个方法体里面都写一些模板化的 try-catch 的代码, 代码不但不美观, 也增加了维护的难度, 特别是还需要对 Service 层的不同异常进行不同处理的时候.
@ControllerAdvice
注解是 Spring 3.2 中新增的. 用于拦截全局的 Controller 的异常
. 注意:该注解只能拦截 Controller 不能拦截 Interceptor 的异常.
全局异常处理的步骤
- 在 SpringMVC / S