Spring cloud项目扩展(一)全局异常处理

最近区块链技术又重燃旧火,自己也想在这把火中,学习一下,于是下了一套源码进行学习。看代码的时候看到了这个全局异常处理的方式。其实在Spring cloud项目中使用全局异常处理也是比较好的,现在实际项目中也是在使用这种方式,所以记录在此记录一下。

       首先说一下思路。第一,我们在进行项目开发的时候,会把对数据库操作的事务放在service层中进行处理,遇到错误抛出异常,通过事务管理可以进行回滚操作。所有的异常都需要被controller层捕获,如果在controller中处理大量异常会让代码变的相当难看。第二,集中处理异常可以对异常进行一些持久化操作,比如存入数据库。我们可以在项目中做出一个异常查看功能,如果遇到问题需要查看日志,很多时候只需要查看一下异常就可以分析到问题的原因,而不用再登录服务器进行分析日志了。下面开始写一下实现。实现还是比较简单的。

       1,首先定义一个异常全局处理类GlobalExceptionHandler,类要用
@ControllerAdvice注解修饰。

Spring cloud项目扩展(一)全局异常处理

        2,使用@ExceptionHandler注解来定义个全局的处理方法exceptionHandler。

Spring cloud项目扩展(一)全局异常处理

        3,正常情况下,在这里return一个字符串+异常就可以了。但是接下来我们要把异常存入数据库中。我们在exceptionHandler()方法中调用handleErrorInfo。

Spring cloud项目扩展(一)全局异常处理

        4,再封装一个存库的方法saveException。

Spring cloud项目扩展(一)全局异常处理

        5,有一个地方要注意,看过我前面的文章的知道我们有一个extra moudle是专门用来做一些全局的事情的。所以这个全局日志记录就放在这个模块里。因为这个模块会打成一个jar包,所以这里存储日志的时候使用的是EurekaClient来实现。我们只需要把EurekaClient注入进来,通过client调用别的微服务模块进行存储日志即可。别的模块的从controller-service-dao这些我就不写了,就是一个简单的增删改查。

Spring cloud项目扩展(一)全局异常处理