Spring全局异常捕获不生效问题的解决办法

 更新时间:2024年04月24日 11:27:18   作者:Lvlht  
Spring项目全局异常处理不生效,登录接口报错异常信息被直接返回到接口响应中,本文给大家介绍了Spring全局异常捕获不生效问题的解决办法,文中有详细的图文介绍,需要的朋友可以参考下

问题场景:

Spring项目全局异常处理不生效,登录接口报错异常信息被直接返回到接口响应中。

问题描述

同事反馈说系统登录报错,查看接口响应,堆栈信息直接返回前台了,Debug代码发现全局异常捕获也没有生效。

原因分析:

先梳理一下Spring全局异常拦截的逻辑:

一,Spring在org.springframework.web.servlet.DispatcherServlet#doDispatch内部方法调用加了try catch机制,拦截所有Exception异常。

在这里插入图片描述

二,DispatcherServlet#processDispatchResult方法内部再次调用了processHandlerException方法。

在这里插入图片描述

三,processHandlerException 方法负责在 Spring MVC 中协调处理处理器执行过程中发生的异常。它首先清理响应状态,然后尝试通过一系列注册的 HandlerExceptionResolver 找到合适的异常处理策略,并最终返回一个用于渲染错误页面的 ModelAndView 对象,或者在未能妥善处理异常时重新抛出异常。

在这里插入图片描述

解决方案:

先确定异常类型,再检查异常抛出位置。

  1. BadSqlGrammarException异常的祖先类继承了Exception,所以DispatcherServlet#doDispatch方法肯定是可以捕获该异常的,所以出现问题的原因就在于该异常可能未经过doDispatch方法。
  2. 检查代码报错逻辑是在org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter方法中。
  3. Sevlet容器定义的组件执行顺序有filter -> servlet -> interceptor -> Controller。
  4. 所以在filter层抛出的异常,理论上只能在filter层解决,最简单的方式就是定义一个order靠前的ExceptionFilter来捕获后续filter异常。另外也可以基于Tomcat容器来配置全局异常消除:
    • 在server.xml中添加一个ErrorReportValve,将showReport设置为false就隐藏了详细报错信息,showServerInfo设置为false是隐藏Tomcat版本信息。
\<Valve className="org.apache.catalina.valves.ErrorReportValve"
showReport="false"
showServerInfo="false" />

以上就是Spring全局异常捕获不生效问题的解决办法的详细内容,更多关于Spring全局异常捕获不生效的资料请关注脚本之家其它相关文章!

相关文章

  • Java使用正则表达式截取重复出现的XML字符串功能示例

    Java使用正则表达式截取重复出现的XML字符串功能示例

    这篇文章主要介绍了Java使用正则表达式截取重复出现的XML字符串功能,涉及java针对xml字符串及指定格式字符串的正则匹配相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • springboot ElasticSearch如何配置自定义转换器ElasticsearchCustomConversions

    springboot ElasticSearch如何配置自定义转换器ElasticsearchCustomConver

    这篇文章主要介绍了springboot ElasticSearch如何配置自定义转换器ElasticsearchCustomConversions问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • fasterxml jackson反序列化时对于非静态内部类报错问题及解决

    fasterxml jackson反序列化时对于非静态内部类报错问题及解决

    这篇文章主要介绍了fasterxml jackson反序列化时对于非静态内部类报错问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • java中RabbitMQ高级应用

    java中RabbitMQ高级应用

    本文主要介绍了java中RabbitMQ高级应用,中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • Java多线程join方法实例代码

    Java多线程join方法实例代码

    这篇文章主要介绍了Java多线程join方法实例代码,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2018-02-02
  • Java字符串逆序方法详情

    Java字符串逆序方法详情

    这篇文章主要介绍了Java字符逆序,字符逆序主要原理就是将一个字符串str的内容颠倒过来,并输出,下文操作分享需要的小伙伴可以参考一下
    2022-03-03
  • Java getResource()如何获取class文件目录位置

    Java getResource()如何获取class文件目录位置

    这篇文章主要介绍了Java getResource()如何获取class文件目录位置,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 使用SQL保留两位小数的实现方式

    使用SQL保留两位小数的实现方式

    SQL中保留两位小数有三种方法:1、使用ROUND()函数进行四舍五入;2、使用CONVERT()函数和3、CAST()函数进行强制类型转换,这两种方法会截断多余的位数,ROUND()函数会保留0位,而CONVERT()和CAST()会删除多余的0
    2024-11-11
  • sprinboot项目启动一半到图形化界面卡住了的解决

    sprinboot项目启动一半到图形化界面卡住了的解决

    这篇文章主要介绍了sprinboot项目启动一半到图形化界面卡住了的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • SpringBoot中统计方法耗时的七种实现方式小结

    SpringBoot中统计方法耗时的七种实现方式小结

    作为开发者,我们经常需要统计方法的执行时间,以便找出性能瓶颈,优化系统响应速度,今天分享在SpringBoot框架中实现方法耗时统计的几种方法,大家可以根据需求自行选择
    2025-03-03

最新评论