作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬
学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
基本处理流程图
自定义异常页面
我们自定义一个错误页面吧,比如我想用Thymeleaf
来渲染,那得导入这个包,然后我们知道错误错误视图名字叫做error
,所以得有这样一个页面,创建一个error.html
放在resources/templates/
下:
内容就是:
这些属性哪里来的,debug
里看到的,其实是过程当中一步步设置进去的啦,有兴趣你可以跟一下:
最终结果:
自定义异常处理方法
自定义异常增强类,处理方法得有ExceptionHandler
注解,注解属性里面也可以定义异常类型,不过这个只能用于HandlerMethod
处理:
处理方法:
my_error.html
:
为什么只能用于HandlerMethod
处理,就看ExceptionHandlerExceptionResolver
的匹配方法:
然后在处理的时候有这么一段,就是获取我们自定义的异常处理方法,封装成ServletInvocableHandlerMethod
对象:
最后调用:
得到模型视图结果返回:
最后ThymeleafView
会解析出视图然后渲染:
结果就是:
不是HandlerMethod
处理的就是这样:
自定义异常处理方法原理也讲了,基本应该能理解了,但是值能用于方法处理的异常,前面的/cr
异常还是原来的处理,后面我们再来个都能处理的方案。