拦截webapp下jsp_Spring MVC中的拦截器/过滤器HandlerInterceptorAdapter的使用
I分享永久IDEA激活码:ntelliJ IDEA 2020.1.2 激活码,永久有效(点击该链接)!
一般情况下,对来自浏览器的请求的拦截,是利用Filter实现的
而在Spring中,基于Filter这种方式可以实现Bean预处理、后处理。 比如注入FilterRegistrationBean,然后在这个Bean上传递自己继承Filter实现的自定义Filter进入即可。
而Spring MVC也有拦截器,不仅可实现Filter的所有功能,还可以更精确的控制拦截精度。
Spring MVC提供的org.springframework.web.servlet.handler.HandlerInterceptorAdapter这个适配器,继承此类,可以非常方便的实现自己的拦截器。
它有三个方法:
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception { 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在业务处理器处理请求之前被调用。预处理,可以进行编码、安全控制等处理;
postHandle在业务处理器处理请求执行完成后,生成视图之前执行。后处理(调用了Service并返回ModelAndView,但未进行页面渲染),有机会修改ModelAndView;
afterCompletion在DispatcherServlet完全处理完请求后被调用,可用于清理资源等。返回处理(已经渲染了页面),可以根据ex是否为null判断是否发生了异常,进行日志记录;
如果基于XML配置使用Spring MVC,可以利用SimpleUrlHandlerMapping、BeanNameUrlHandlerMapping进行Url映射(相当于struts的path映射)和拦截请求(注入interceptors)。
如果基于注解使用Spring MVC,可以使用DefaultAnnotationHandlerMapping注入interceptors。
注意无论基于XML还是基于注解,HandlerMapping Bean都是需要在XML中配置的。
示例一:
在这个例子中,我们假设UserController中的注册操作只在9:00-12:00开放,那么就可以使用拦截器实现这个功能。
public class TimeBasedAccessInterceptor extends HandlerInterceptorAdapter {private int openingTime;private int closingTime;private String mappingURL;//利用正则映射到需要拦截的路径public void setOpeningTime(int openingTime) { this.openingTime = openingTime; }public void setClosingTime(int closingTime) { this.closingTime = closingTime; }public void setMappingURL(String mappingURL) { this.mappingURL = mappingURL; }@Overridepublic boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception { String url=request.getRequestURL().toString(); if(mappingURL==null || url.matches(mappingURL)){ Calendar c=Calendar.getInstance(); c.setTime(new Date()); int now=c.get(Calendar.HOUR_OF_DAY); if(nowclosingTime){ request.setAttribute("msg", "注册开放时间:9:00-12:00"); request.getRequestDispatcher("/msg.jsp").forward(request, response); return false; } return true; } return true;}
XML配置:
<bean id="timeBasedAccessInterceptor" class="com.spring.handler.TimeBasedAccessInterceptor"> <property name="openingTime" value="9" /> <property name="closingTime" value="12" /> <property name="mappingURL" value=".*/user\.do\?action=reg.*" /> bean> <bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"> <property name="interceptors"> <list> <ref bean="timeBasedAccessInterceptor"/> list> property> bean>
这里我们定义了一个mappingURL属性,实现利用正则表达式对url进行匹配,从而更细粒度的进行拦截。当然如果不定义mappingURL,则默认拦截所有对Controller的请求。
UserController:
@Controller@RequestMapping("/user.do")public class UserController{@Autowiredprivate UserService userService;@RequestMapping(params="action=reg")public ModelAndView reg(Users user) throws Exception { userService.addUser(user); return new ModelAndView("profile","user",user); }// other option ...
也可以配置多个拦截器,每个拦截器进行不同的分工。
示例二:
主要是XML配置不一样
<mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/" /> <mvc:mapping path="/user/**" /> <mvc:mapping path="/test/**" /> <bean class="com.alibaba.interceptor.CommonInterceptor">bean> mvc:interceptor> mvc:interceptors>
package com.alibaba.interceptor;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.web.servlet.ModelAndView;import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;import com.alibaba.util.RequestUtil;public class CommonInterceptor extends HandlerInterceptorAdapter{ private final Logger log = LoggerFactory.getLogger(CommonInterceptor.class); public static final String LAST_PAGE = "com.alibaba.lastPage";/** 利用正则映射到需要拦截的路径private String mappingURL;public void setMappingURL(String mappingURL) {this.mappingURL = mappingURL;}*//*** 在业务处理器处理请求之前被调用* 如果返回false* 从当前的拦截器往回执行所有拦截器的afterCompletion(),再退出拦截器链* 如果返回true* 执行下一个拦截器,直到所有的拦截器都执行完毕* 再执行被拦截的Controller* 然后进入拦截器链,* 从最后一个拦截器往回执行所有的postHandle()* 接着再从最后一个拦截器往回执行所有的afterCompletion()*/@Overridepublic boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception { if ("GET".equalsIgnoreCase(request.getMethod())) { RequestUtil.saveRequest(); } log.info("==============执行顺序: 1、preHandle================"); String requestUri = request.getRequestURI(); String contextPath = request.getContextPath(); String url = requestUri.substring(contextPath.length()); log.info("requestUri:"+requestUri); log.info("contextPath:"+contextPath); log.info("url:"+url); String username = (String)request.getSession().getAttribute("user"); if(username == null){ log.info("Interceptor:跳转到login页面!"); request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response); return false; }else return true;}/*** 在业务处理器处理请求执行完成后,生成视图之前执行的动作* 可在modelAndView中加入数据,比如当前时间*/@Overridepublic void postHandle(HttpServletRequest request,HttpServletResponse response, Object handler,ModelAndView modelAndView) throws Exception { log.info("==============执行顺序: 2、postHandle================"); if(modelAndView != null){ //加入当前时间 modelAndView.addObject("var", "测试postHandle"); }}/*** 在DispatcherServlet完全处理完请求后被调用,可用于清理资源等** 当有拦截器抛出异常时,会从当前拦截器往回执行所有的拦截器的afterCompletion()*/@Overridepublic void afterCompletion(HttpServletRequest request,HttpServletResponse response, Object handler, Exception ex)throws Exception { log.info("==============执行顺序: 3、afterCompletion================"); }}
如有文章对你有帮助,
“在看”和转发是对我大的支持!
关注白码啸西风
每天学习Java技术
拦截webapp下jsp_Spring MVC中的拦截器/过滤器HandlerInterceptorAdapter的使用相关推荐
- spring mvc中的拦截器
本文说下spring MVC中的拦截器 文章目录 拦截器介绍 拦截器注入适配器 自定义拦截器 controller测试 测试结果 本文小结 拦截器介绍 拦截器是在servlet执行之前执行的程序(这里 ...
- MVC中使用Action全局过滤器出现:网页无法正常运作 将您重定向的次数过多。解决办法
今天用本地测试出现将您重定向的次数过多的错误提示,搜索到这篇文章,大概看懂了意思. 我自己的是tp的登录页面提示重定向,我查到问题是logincontroller.class.php 前面继承了com ...
- Spring MVC中的拦截器/过滤器HandlerInterceptorAdapter的使用
转载自 https://www.cnblogs.com/EasonJim/p/7704740.html 一般情况下,对来自浏览器的请求的拦截,是利用Filter实现的 而在Spring中,基于Filt ...
- jsp中的url拼接的参数传递到controller乱码_Spring MVC中的拦截器
拦截器是 AOP 编程思想的典型应用 详述 Spring MVC 框架中拦截器 Interceptor 的使用方法blog.csdn.net 实现 1:创建一个controller类 package ...
- Spring mvc中自定义拦截器
一.要实现的一个功能: 1.打开特定的一些页面时必需强制用户进行登录. 2.登录后再返回到之前的页面. 二.先写一个service,实现从cookie中判断用户是否登录. 1.TT_TOKEN为登录成 ...
- java 中prehandle_Spring MVC中拦截器HandlerInterceptorAdapter中的preHandle方法
拦截器:顾名思义,就是对请求进行拦截,做一些预处理.后处理或返回处理的操作 Spring MVC中使用拦截器的方法,继承HandlerInterceptorAdapter类,并根据需求实现其中的pre ...
- vue面向切面_vue:在路由跳转中使用拦截器
1:首先在路由对象中的某一个具体的路由对象加这样一个属性 meta: { requireAuth:true } 2:然后在main.js中添加这段代码 router.beforeEach((to, ...
- Spring mvc中@RequestMapping 6个基本用法小结
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 小结下spring mvc中的@RequestMapping的用法. 1)最基本的,方法级别上应用, ...
- mvc html validator,ASP.NET MVC实现Validation验证器扩展
今天介绍在ASP.NET MVC实现Validation验证器扩展,通过使用Controller验证并不是最好的方法:验证过于分散,容易造成重复代码,不利于维护与扩展,因此本节将使用MVC默认绑定器( ...
最新文章
- ASP.NET Core Web Razor Pages系列教程:使用ASP.NET Core创建Razor Pages Web应用程序
- [linux]解决vsftpd 读取目录列表失败的问题
- nginx配置ssl证书的方法
- MAMP 403 Forbidden You don't have permission to access / on this server.
- javascript客户端验证函数大全
- oracle数据库技术_创建 pdb数据库
- 解决谷歌浏览器flash插件已被屏蔽
- 《实战java程序设计---上》
- echart-pie
- 第一篇 安卓系统的介绍及特点
- Arduino-超声波测距模块
- 惊闻同事噩耗,思绪联翩
- 追觅、小狗、戴森吸尘器对比测评,让你了解哪款最好用
- 学Java 这样入门 28天轻松掌握
- 以太坊的交易树和收据树
- mysql获取今天的最后一秒_在MySQL中获取日期的最后一秒?
- 从泊松方程到泊松融合(Poisson Matting)
- 编写一个类,实现简单的栈(提示:用链表结构实现)。数据的操作按先进后出(FILO)的顺序。
- abb机器人示教器io信号关联_ABB机器人IO基本操作接线练习
- 19 、(5分)成绩的学分绩点计算
热门文章
- html 鼠标中键事件,Javascript事件模拟(鼠标事件、键盘事件)
- asps英文_唯美的英语单词,超唯美的英文单词有哪些
- 109aix和linux虚拟化技术支持中文版
- (转)2011-12-17 百度技术沙龙学习笔记
- 谈谈自己对机器学习如何学习以及未来职业方向的理解(不断更新中)
- 【牛客基础】after与迷宫(bfs+理解题目)
- 360加固保的dex脱壳方法
- 2018复旦大学计算机硕士招生复试上机题(2)-解一元一次方程
- AntV | 蚂蚁数据可视化 G2Plot 快速入门
- 二进制加法器的VHDL程序