(三)一步步来开始SSM:拦截器实现
上一篇文章[(二)一步步来开始SSM:数据连通测试]
1、拦截器类
在项目中新建一个文件夹filter,创建一个编码拦截器EncodingFilter实现HandlerInterceptor接口,所有的拦截器类都需要通过实现这个接口来对请求进行拦截。
HandlerInterceptor接口中需要实现三个方法:
1、preHandle 该方法将在请求处理之前进行调用,只有该方法返回true,才会继续执行后续的Interceptor和Controller,当返回值为true 时就会继续调用下一个Interceptor的preHandle 方法,如果已经是最后一个Interceptor的时候就会是调用当前请求的Controller方法;
2、postHandle 该方法也是需要当前对应的Interceptor的preHandle方法的返回值为true时才会执行,该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行。用于进行资源清理。
3、afterCompletion 该方法将在请求处理之后,DispatcherServlet进行视图返回渲染之前进行调用,可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作。
执行顺序为:preHandler -> Controller -> postHandler -> model渲染-> afterCompletion
package com.libraryManage.filter;import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;public class EncodingFilter implements HandlerInterceptor {public boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception {request.setCharacterEncoding("utf-8");response.setCharacterEncoding("utf-8");return true;}public void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception {}public void afterCompletion(HttpServletRequest request,HttpServletResponse response, Object handler,Exception ex) throws Exception {}
}
在该拦截其中,preHandle方法对编码格式进行设置,保证后续的数据传递没有乱码问题。
2、配置文件加入拦截器
spring-mvc.xml文件
<!-- 自定义的拦截器 -->
<mvc:interceptors><!-- 编码拦截器 --><mvc:interceptor><mvc:mapping path="/**"/><bean class="com.libraryManage.filter.EncodingFilter" /></mvc:interceptor></mvc:interceptors>
<mvc:mapping>标签是需要拦截的路径
<bean>标签是拦截器类的路径
每个拦截器都必须有以上两个标签,且标签的顺序不能乱
还有一个<mvc:exclude-mapping>标签,用来过滤不需要拦截的一些请求。我在使用这个标签时遇到idea标红报错的提示,将上面的路径进行修改就可以了,如下图所示:将原来的spring-mvc-3.0.xsd改为spring-mvc-3.2.xsd。
3、拦截器的常见应用场景
1、权限检查:如检测请求是否具有登录权限,如果没有直接返回到登陆页面。
2、性能监控:用请求处理前和请求处理后的时间差计算整个请求响应完成所消耗的时间。
3、日志记录:可以记录请求信息的日志,以便进行信息监控、信息统计等。
4、用拦截器实现登录权限校验
管理员登录拦截AdminLoginFilter类,如果缓存中没有拿到管理员的登录信息,对该请求进行拦截并且页面重定向到登录页。
package com.libraryManage.filter;import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;public class AdminLoginFilter implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,Object o) throws Exception {HttpSession session = httpServletRequest.getSession();Object admin = session.getAttribute("admin");if (admin == null) {// 获取项目根路径ServletContext context = httpServletRequest.getServletContext();String basePath = String.valueOf(context.getAttribute("project_access_path"));httpServletResponse.sendRedirect(basePath + "/index.jsp");}return true;}@Overridepublic void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,Object o, ModelAndView modelAndView) throws Exception {}@Overridepublic void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,Object o, Exception e) throws Exception {}
}
配置文件spring-mvc.xml,只有访问登录页面和登录接口时不进行拦截
<!-- 自定义的拦截器 --><mvc:interceptors><!-- 编码拦截器 --><mvc:interceptor><mvc:mapping path="/**"/><bean class="com.libraryManage.filter.EncodingFilter" /></mvc:interceptor><!-- 管理员登录拦截 --><mvc:interceptor><mvc:mapping path="/**/*.do" /><mvc:exclude-mapping path="/index.jsp" /><mvc:exclude-mapping path="/admin/login.do" /><bean class="com.libraryManage.filter.AdminLoginFilter"></bean></mvc:interceptor></mvc:interceptors>
5、扩展:在配置文件中自定义参数
在上面的拦截器跳转重定向时,选择的路径为项目的根路径再加上登录页面,我们在配置文件中对项目的根路径进行配置,这样直接在代码中获取到配置的路径,增加代码的灵活性。
spring-mvc.xml文件中加入了以下代码:
<!-- 自定义参数 --><bean class="org.springframework.web.context.support.ServletContextAttributeExporter"><property name="attributes"><map><!-- 项目访问路径 --><entry key="project_access_path" value="http://localhost:8080/library"/></map></property>
(三)一步步来开始SSM:拦截器实现相关推荐
- SSM拦截器和过滤器结合使用-实现登录拦截操作
我的主要思路是:使用过滤器filter实现对前台页面的拦截(包括.jsp.css.images.js),使用拦截器interceptor实现对后台所有请求的拦截(登陆请求除外). 文件位置如下,下图是 ...
- SpringMVC学习总结(三):转发重定向、拦截器、文件上传等
转发和重定向 当Controller中方法的返回值为字符串时,默认为视图名称.当返回值字符串以"forward:"或者"redirect:"开头,则会被认为是转 ...
- Spring拦截器配置详解(如何定义一个拦截器)
一.前言 Spring和SpringBoot的拦截器也是对请求进行的系列验证或处理,关于拦截器和过滤器的区别此文不做介绍,之前我看到过一篇相关系列的文章,讲述的还比较详细,给大家参考参考:拦截器与过滤 ...
- SpringMVC之拦截器
目录 一.什么是拦截器? 二.拦截器与过滤器 三.应用场景 四.拦截器入门案例 五.拦截器方法说明 六.用户登录权限控制 一.什么是拦截器? SpringMVC的处理器拦截器,类似于Servlet开发 ...
- axios拦截器_78.1K 的 Axios 项目有哪些值得借鉴的地方
Axios 是一个基于 Promise 的 HTTP 客户端,同时支持浏览器和 Node.js 环境.它是一个优秀的 HTTP 客户端,被广泛地应用在大量的 Web 项目中. 由上图可知,Axios ...
- 过滤器跟拦截器的区别
一.拦截器与过滤器的区别总结 1. 原理不同:拦截器是基于java的反射机制的,而过滤器是基于函数回调. 2. 依赖容器:拦截器不依赖与servlet容器,过滤器依赖与servlet容器. 3. 作用 ...
- CXF 入门:创建一个基于SOAPHeader的安全验证(CXF拦截器使用)
CXF拦截器使用,创建一个使用SOAPHeader的安全验证xml格式: <soap:Header><auth:authentication xmlns:auth="htt ...
- Spring mvc中自定义拦截器
一.要实现的一个功能: 1.打开特定的一些页面时必需强制用户进行登录. 2.登录后再返回到之前的页面. 二.先写一个service,实现从cookie中判断用户是否登录. 1.TT_TOKEN为登录成 ...
- Hadoop生态Flume(四)拦截器(Interceptor)介绍与使用(2)
转载自 Flume中的拦截器(Interceptor)介绍与使用(二) lume中的拦截器(interceptor),用户Source读取events发送到Sink的时候,在events header ...
- SpringMVC-HandlerInterceptor拦截器的使用与参数详解
拦截器概念: 拦截器( Interceptor)是一种动态拦截方法调用的机制,请求处理过程解析 核心原理: AOP思想 拦截器链:多个拦截器按照一定的顺序,对原始被调用功能进行增强 作用: 在指定的方 ...
最新文章
- YOLOv4没交棒,但YOLOv5来了!
- 呵呵,哈哈,嘿嘿,从今天起就开始写博客文了
- Ubuntu apt 卸载详解
- 昂靠的由来[本博作者爆料]
- hadoop整合纪要
- websocket网络层详解_【技术分享】WebSocket漏洞与防护详解
- python测试用例管理_Python测试框架Pytest的常用插件测试报告
- 自执行匿名函数剖析整理
- php 获取当前url hash,PHP hash 接口对接
- python 动态类型_动态类型(Dynamic type)
- Java-发送邮件descriptor
- 高中生住校好还是走读好?为什么?
- 谈谈java中的集合框架
- 数组的连续最大子段合
- 五种常用源代码开源协议
- 【Python】爬取TapTap原神评论并生成词云分析
- 优秀!3位95后硕士一作发表Nature!
- 如何在浏览器中打开jupyter notebook
- 【毕业设计】深度学习图像风格迁移算法研究与实现 - python 卷积神经网络
- VMware虚拟机安装Ubuntu kylin 麒麟系统教程 超详细