46、SpringBoot2.x源码分析:SpringMVC源码细节之异常处理二

Spring Boot 2.2.6 源码之旅四十五SpringMVC源码细节之异常处理二

  • 基本处理流程图
  • 继续抛异常

基本处理流程图

*

继续抛异常

继续上篇的,异常没法被异常解析器处理,继续抛出:
*
拦截器处理完后继续抛出:
*
FrameworkServlet封装成嵌套的NestedServletException继续抛:
*
不过下面会打印信息:
*
内部会打印:
*
一路抛到org.apache.catalina.core.StandardWrapperValveinvoke,输出异常信息,用exception方法处理响应设置:
*
*
设置响应状设置错误状态errorState=1
*
然后继续执行:
*
最后到这里找到默认的报错页面:
*
*
然后一通属性请求和响应设置之后到这里:
*
内部然后进行转发到/err.
*
然后请求又进来,要分发了,这个请求最后被BasicErrorControllererrorHtml方法处理,所以可以看到视图名字是error啦:
*
最后是StaticView来渲染:
*
是一堆拼起来的信息:
*

渲染出来的页面就是我们熟悉的:
*

好了异常处理页面原理大致了解了,其实默认不处理是会在tomcat进行转发/err,最后到上层由一个叫BasicErrorController的处理器处理,最后渲染/error视图,当然这个是StaticView字符串拼起来的。
下篇看能不能做一些定制,比如错误页面,或者自己处理错误等等。至于说静态页面视图/error哪来的,其实tomcat服务器创建的时候添加的,看左边堆栈信息:
*

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。