在SpringBoot中配置全局捕获异常
前言
之前写过一篇博客是使用spring利用HandlerExceptionResolver实现全局异常捕获
里面使用spring的HandlerExceptionResolver接口来实现全局的异常捕获,当时使用,但其实之后已经替换
当前项目中使用的是:@ControllerAdvice 、@ExceptionHandler通过这两个注解来实现全局的异常捕获
已经加入我的github模版中:https://github.com/LinkinStars/springBootTemplate
实现
创建GlobalExceptionResolver,实现如下:
import com.linkinstars.springBootTemplate.exception.ServiceException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;
/**
* 全局异常处理
* @author LinkinStar
*/
@ControllerAdvice
public class GlobalExceptionResolver {
@ExceptionHandler(value = ServiceException.class)
public @ResponseBody String serviceCommonExceptionHandler(ServiceException e) {
//对捕获的异常进行处理并打印日志等,之后返回json数据,方式与Controller相同
return "{'code':-1}";
}
@ExceptionHandler(value = Exception.class)
public ModelAndView exceptionHandler() {
//当然也可以直接返回ModelAndView等类型,然后跳转相应的错误页面,这都根据实际的需要进行使用
return new ModelAndView();
}
}
其中ServiceException是自定义的异常
/**
* 自定义异常
* @author LinkinStar
*/
public class ServiceException extends RuntimeException{
}
spring会根据ExceptionHandler中的值进行匹配,如果你的一些异常没有被捕获,这里就会处理一些你没有捕获的异常
至于你需要返回一个页面还是需要返回一个json数据,这就看实际的业务场景了。
使用原因
在之前的博客中也提出,spring官方推荐这样的写法,但当时没有在意,在实际使用中出现问题后,最终还是采用了这样的方式,理由主要有下面几点:
1、使用注解的方式代码看上去更加的清晰。
2、对于自定义异常的捕获会很方便。
3、适用于对于返回json格式的情况(可以使用@ResponseBody注解方法对特定异常进行处理),使用HandlerExceptionResolver的话如果是ajax的请求,出现异常就会很尴尬,ajax并不认识ModelAndView。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
2017-03-06 手把手教你用Mysql-Cluster-7.5搭建数据库集群
2016-03-06 java发布项目后注意小点,以及对于金额在java中的处理