SpringMVC的拦截器和异常处理器
目录
lerInterceptor 拦截器
1、拦截器的作用
2、拦截器的创建
3、拦截器的三个抽象方法
4、拦截器的配置
5、多个拦截器的执行顺序
SpringMVC的异常处理器
1、异常处理器概述
2、基于配置文件的异常处理
3、基于注解的异常处理
lerInterceptor 拦截器
1、拦截器的作用
拦截器的作用时机
SpringMVC的拦截器作用于
控制器方法执行的前后。有不同的拦截方法,作用于控制器方法执行之前、之后、以及视图渲染之后三个阶段
拦截器与过滤器的区别
过滤器是原生Serlvet的组件,作用于Servlet执行之前
拦截器是SpringMVC的模块,作用于控制器方法执行前、后、渲染视图后。
2、拦截器的创建
SpringMVC中的拦截器需要实现HandlerInterceptor接口
示例
public class FirstInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {System.out.println("控制器方法准备执行...");return true;}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {System.out.println("控制器方法执行完毕...");}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {System.out.println("视图渲染完毕...");}
}
3、拦截器的三个抽象方法
HandlerInterceptor接口有三个抽象方法:
- preHandle:
控制器方法执行之前执行preHandle(),其boolean类型的返回值表示是否拦截或放行
返回true为放行,即调用控制器方法;返回false表示拦截,即不调用控制器方法- postHandle:
控制器方法执行之后执行postHandle()- afterComplation:处理完视图和模型数据,
渲染视图完毕之后执行afterComplation()
源码分析,为什么preHandle能实现拦截控制器方法
//DispatherServlet
if (!mappedHandler.applyPreHandle(processedRequest, response)) {//如果applyPreHandle方法返回的是false,就直接return,不再执行下面的内容return;
}//执行控制器方法
mv = ha.handle(processedRequest, response, mappedHandler.getHandler());
//渲染视图
...//applyPreHandle方法
boolean applyPreHandle(HttpServletRequest request, HttpServletResponse response) throws Exception {for (int i = 0; i < this.interceptorList.size(); i++) {HandlerInterceptor interceptor = this.interceptorList.get(i);if (!interceptor.preHandle(request, response, this.handler)) {triggerAfterCompletion(request, response, null);//如果当前拦截器的preHandle方法返回false,applyPreHandle方法也返回falsereturn false;}this.interceptorIndex = i;}return true;
}
注意
SpringMVC配置文件中的
view-controller视图控制器标签,也会被拦截器拦截。
4、拦截器的配置
SpringMVC的拦截器必须在SpringMVC的配置文件中进行配置。
拦截器有三种配置方式,一般使用第三种,可以配置拦截范围。
方式一 在interceptors中配置自定义拦截器的bean标签
<!--配置拦截器-->
<mvc:interceptors><bean class="com.csai.interceptors.FirstInterceptor"/>
</mvc:interceptors>
这种方式
无法指定拦截范围,是对DispatcherServlet所处理的所有的请求进行拦截
方式二 在interceptors中引用自定义拦截器的bean id
<bean id="firstInterceptor" class="com.csai.interceptors.FirstInterceptor"/><!--配置拦截器-->
<mvc:interceptors><ref bean="firstInterceptor"/>
</mvc:interceptors>
和上面一样,这种方式
无法指定拦截范围,是对DispatcherServlet所处理的所有的请求进行拦截配置自定义拦截器的bean时,可以使用配置文件,也可以使用@Component注解+组件扫描的方式
方式三 使用<mvc:interceptor>标签进行配置
<bean id="firstInterceptor" class="com.csai.interceptors.FirstInterceptor"/><!--配置拦截器-->
<mvc:interceptors><mvc:interceptor><mvc:mapping path="/**"/><mvc:exclude-mapping path="/testInterceptor"/><ref bean="firstInterceptor"/></mvc:interceptor>
</mvc:interceptors>
可以配置三个属性:
- mapping:
拦截请求的请求地址,可以使用Ant风格的路径- exclude-mapping:
不会被拦截的请求地址,即拦截白名单- bean/ref:指定拦截器的bean
例如这里是拦截所有请求,不拦截testInterceptor页面,对应的拦截器是firstInterceptor
5、多个拦截器的执行顺序
如果匹配到的多个拦截器的preHandle()方法都返回true
此时多个拦截器的执行顺序和拦截器在SpringMVC的配置文件的配置顺序有关:
preHandle()会按照配置的顺序执行,即先配置的先执行
postHandle()和afterComplation()会按照配置的反序执行,即先配置的后执行,因为是嵌套的关系。示例,请求访问,匹配到一个控制器方法,两个拦截器:
配置顺序:
<!--配置拦截器-->
<mvc:interceptors><ref bean="Interceptor A"/><ref bean="Interceptor B"/>
</mvc:interceptors>
执行顺序:
preHandle A --> true
preHandle B --> true
--- 控制器方法执行 ---
--- 控制器方法执行完毕 ---
postHandle B
postHandle A
--- 视图渲染完毕 ---
afterComplation B
afterComplation A
如果匹配到多个拦截器,有的拦截器的preHandle()方法返回了false
先看结果:对于同一个控制器方法,只要存在拦截器的preHandle()方法返回了false,控制器方法就不会执行。
- 在它之前配置的拦截器,和它自己的preHandle()都会执行
- 所有的postHandle()都不执行,因为控制器方法没有执行
- 在它之前配置的拦截器,afterComplation()会执行
- 在它之后配置的拦截器,所有方法都不会执行。
示例 请求访问,匹配到一个控制器方法,两个拦截器,其中一个返回false:
配置顺序:
<!--配置拦截器-->
<mvc:interceptors><ref bean="Interceptor A"/><ref bean="Interceptor B"/>
</mvc:interceptors>
Interceptor B 的preHandle()返回false
执行顺序:
preHandle A --> true
preHandle B --> false
--- 控制器方法不执行 ---
afterComplation A
SpringMVC的异常处理器
1、异常处理器概述
异常处理器的作用
用于处理SpringMVC 控制器方法执行过程中 产生的异常。
SpringMVC提供了一个处理 控制器方法执行过程中所出现的异常的接口:
HandlerExceptionResolverHandlerExceptionResolver接口的实现类:
- DefaultHandlerExceptionResolver,是SpringMVC默认使用的异常处理器
- SimpleMappingExceptionResolver,用于自定义 异常处理器
自定义异常处理器的使用场景
大致有两个作用:
- 对系统异常提供自定义处理。比如出现某个异常时,跳转到服务器繁忙的页面,用户就不会看到500这类的页面了
- 提供对自定义异常的处理方案
2、基于配置文件的异常处理
SpringMVC提供了自定义的异常处理器SimpleMappingExceptionResolver
示例 实现错误页面跳转
<!--配置异常处理器-->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"><property name="exceptionMappings"><props><!--如果出现ArithmeticException数学异常,就跳转到error视图--><prop key="java.lang.ArithmeticException">error</prop></props></property>
</bean>
properties的键表示处理器方法执行过程中出现的异常
properties的值表示若出现指定异常时,设置一个新的视图名称,跳转到指定页面
测试
error页面
<h3>服务器繁忙!</h3>控制器方法
@RequestMapping("/testInterceptor")
public String testInterceptor(){//创造一个数学异常Integer i = 3/0;return "success";
}
发生异常后,就会被自定义的异常处理器捕获,跳转到错误页面
示例 实现异常信息的捕获
配置文件
<!--配置异常处理器-->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"><property name="exceptionMappings"><props><!--如果出现ArithmeticException数学异常,就跳转到error视图--><prop key="java.lang.ArithmeticException">error</prop></props></property><property name="exceptionAttribute" value="exception"/>
</bean>
配置exceptionAttribute属性,设置一个value
异常信息就会存入request域中,键名为设置的value,值为异常信息。
前端页面展示错误信息
<h3>服务器繁忙!</h3>
<p th:text="${exception}"></p>
3、基于注解的异常处理
使用注解,实现获取异常信息和跳转错误页面
@ControllerAdvice
public class ExceptionController {@ExceptionHandler(value = {ArithmeticException.class})public String testException(Exception exception, Model model){model.addAttribute("exception", exception);return "error";}}
原理:如果遇到了@ExceptionHandler 注解 标识的这些异常,就调用 此 @ExceptionHandler 注解对应的控制器方法。
使用注解,在配置文件中就不需要配置任何关于异常处理器的内容。
相关文章:
SpringMVC的拦截器和异常处理器
目录 lerInterceptor 拦截器 1、拦截器的作用 2、拦截器的创建 3、拦截器的三个抽象方法 4、拦截器的配置 5、多个拦截器的执行顺序 SpringMVC的异常处理器 1、异常处理器概述 2、基于配置文件的异常处理 3、基于注解的异常处理 lerInterceptor 拦截器 1、拦截器的作…...
查看库文件是32位还是64位|查看lib是静态库还是导入库|判断是debug模式还是release模式
文章目录 dll位数查看lib位数查看查看lib库是静态库还是导入库dll库文件信息查看lib库文件内容查看dll库查看编译模式是debug还是release方法一方法二方法三 lib静态库查看编译模式是debug还是release方法一方法二 lib导入库查看编译模式是debug还是release查看Linux下的.a库&a…...
Python小姿势 - Python爬取数据的库——Scrapy
Python爬取数据的库——Scrapy 一、爬虫的基本原理 爬虫的基本原理就是模拟人的行为,使用指定的工具和方法访问网站,然后把网站上的内容抓取到本地来。 爬虫的基本步骤: 1、获取URL地址: 2、发送请求获取网页源码; 3、…...
[C++初阶]栈和队列_优先级队列的模拟实现 deque类 的理解
为了更好的理解优先级队列priority_queue,这里会同时进行栈和队列的提及 文章目录 简要概念(栈和队列)栈和队列的模拟实现与使用stack(栈)deque的理解和操作queue priority_queue(优先级队列)框…...
Spring是什么?关于Spring家族
初识Spring 什么是Spring? Spring是一个开源的Java企业级应用程序开发框架,由Rod Johnson于2003年创建,并在接下来的几年里得到了广泛的发展和应用。它提供了一系列面向对象的编程和配置模型,支持开发各种类型的应用程序&#x…...
自然语言处理数据集集锦(持续更新ing...)
诸神缄默不语-个人CSDN博文目录 最近更新时间:2023.4.26 最早更新时间:2023.4.25 文本摘要主题的数据集见我之前写的另一篇博文:文本摘要数据集的整理、总结及介绍(持续更新ing…) 智能司法主题的数据集我准备等项目…...
93、Dehazing-NeRF: Neural Radiance Fields from Hazy Images
简介 论文:https://arxiv.org/pdf/2304.11448.pdf 从模糊图像输入中恢复清晰NeRF 使用大气散射模型模拟有雾图像的物理成像过程,联合学习大气散射模型和干净的NeRF模型,用于图像去雾和新视图合成 通过将NeRF 3D场景的深度估计与大气散射模…...
JAVA子类与继承
目录 JAVA子类与继承 一、子类与父类: 二、子类与对象 三、成员变量的隐藏和方法重写 四、super关键字(P122) 五、final关键字 六、对象的上转型对象(P126) 七、继承与多态(P128) 八、abstract类和…...
62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库
文章目录 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库62.1 创建数据库示例 62.2 查看数据库示例 62.3 选择数据库示例 62.4 删除数据库示例 62.5 备份数据库示例 62.6 恢复数据库示例 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库 62.1 创建数据库…...
【分布式搜索引擎ES01】
分布式搜索引擎ES 分布式搜索引擎ES1.elasticsearch概念1.1.ES起源1.2.倒排索引1.2.1.正向索引1.2.2.倒排索引 1.3.es的一些概念1.3.1.文档和字段1.3.2.索引和映射1.3.3.mysql与elasticsearch 1.4.1安装es、kibana、IK分词器1.4.2扩展词词典与停用词词典 2.索引库操作2.1.mappi…...
1.3 鞅、停时和域流-鞅(布朗运动与随机计算【习题解答】)
Let X = ( x n , F n ) , n = 1 , ⋯ , N X=\left(x_n, \mathcal{F}_n\right), n=1, \cdots, N X...
十、ElasticSearch 实战 - 源码运行
一、概述 想深入理解 Elasticsearch,了解其报错机制,并有针对性的调整参数,阅读其源码是很有必要的。此外,了解优秀开源项目的代码架构,能够提高个人的代码架构能力 阅读 Elasticsearch 源码的第一步是搭建调试环境&…...
GPT-3 论文阅读笔记
GPT-3模型出自论文《Language Models are Few-Shot Learners》是OpenAI在2020年5月发布的。 论文摘要翻译:最近的工作表明,通过对大量文本进行预训练,然后对特定任务进行微调(fine-tuning),在许多NLP任务和基准测试上…...
方案解析丨数字人主播如何成为电商直播新标配
浙江省政府办公厅近日印发《关于进一步扩大消费促进高质量发展若干举措》支持电子商务直播发展。抢抓电子商务直播快速发展机遇,发展数字人虚拟主播、元宇宙新消费场景等新业态新模式。 随着电商直播快速发展,企业怎么高效地实现引流获客,成为…...
Python最全迭代器有哪些?
python中迭代器的使用是最广泛的,凡是使用for语句,其本质都是迭代器的应用。 从代码角度看,迭代器是实现了迭代器协议的对象或类。迭代器协议方法主要是两个: __iter__()__next__() __iter__()方法返回对象本身,他是…...
ESP32 网络计时器,包含自动保存
简介 本代码是基于ESP32开发板实现的一个计时器功能,具备倒计时、计时器时长选择、显示当前时间、有源蜂鸣器报警等功能。代码中使用了WiFi网络连接、NTP时间同步、EEPROM存储等功能。通过按钮控制计时器的开始、停止和计时器时长的选择。 运行原理概述 在ESP32开…...
【ChatGPT】阿里版 ChatGPT 突然官宣意味着什么?
Yan-英杰的主页 悟已往之不谏 知来者之可追 C程序员,2024届电子信息研究生 目录 阿里版 ChatGPT 突然官宣 ChatGPT 技术在 AI 领域的重要性 自然语言生成 上下文连续性 多语言支持 ChatGPT 未来可能的应用场景 社交领域 商业领域 编辑 医疗领域…...
IPEmotion控制模块-PID循环应用
IPEmotion专业版、开发版支持控制模块,并且该模块支持函数发生器、PID控制器、路由器、序列控制和序列控制块以及参考曲线生成器。本文主要针对PID(P:Proportional control 比例控制;I:Integral control 积分控制&…...
【元分析研究方法】学习笔记2.检索文献(含100种学术文献搜索清单链接)
检索文献 该步骤的作用该步骤中需要注意的问题该步骤中部分知识点我的收获 参考来源:库珀 (Cooper, H. M. )., 李超平, & 张昱城. (2020). 元分析研究方法: A step-by step approach. 中国人民大学出版社. 该步骤的作用 1.识别相关文献的来源; 2.识别…...
题目:16版.自由落体
1、实验要求 本实验要求:模拟物体从10000米高空掉落后的反弹行为。 1-1. 创建工程并配置环境: 1-1.1. 限制1. 工程取名:SE_JAVA_EXP_E009。 1-1.2. 限制2. 创建包,取名:cn.campsg.java.experiment。 1-1.3. 限制3. 创建…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
页面渲染流程与性能优化
页面渲染流程与性能优化详解(完整版) 一、现代浏览器渲染流程(详细说明) 1. 构建DOM树 浏览器接收到HTML文档后,会逐步解析并构建DOM(Document Object Model)树。具体过程如下: (…...
数据链路层的主要功能是什么
数据链路层(OSI模型第2层)的核心功能是在相邻网络节点(如交换机、主机)间提供可靠的数据帧传输服务,主要职责包括: 🔑 核心功能详解: 帧封装与解封装 封装: 将网络层下发…...
TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案
一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...
CMake 从 GitHub 下载第三方库并使用
有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
均衡后的SNRSINR
本文主要摘自参考文献中的前两篇,相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程,其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt 根发送天线, n r n_r nr 根接收天线的 MIMO 系…...
云原生玩法三问:构建自定义开发环境
云原生玩法三问:构建自定义开发环境 引言 临时运维一个古董项目,无文档,无环境,无交接人,俗称三无。 运行设备的环境老,本地环境版本高,ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...
vue3 daterange正则踩坑
<el-form-item label"空置时间" prop"vacantTime"> <el-date-picker v-model"form.vacantTime" type"daterange" start-placeholder"开始日期" end-placeholder"结束日期" clearable :editable"fal…...
