SpringMVC
来源:互联网 发布:js获取android版本号 编辑:程序博客网 时间:2024/06/08 09:59
SpringMVC可以使用拦截器对请求进行处理,用户可以实现自定义拦截器。
自定义拦截器必须实现HandlerInterceptor接口。
方法说明如下:
① preHandle()
这个方法在业务处理请求之前被调用,在该方法中对用户请求request进行处理。如果继续调用其他拦截器或者业务处理器,那么忙请返回true;否则返回false。
② postHandle()
这个方法在业务处理器处理完请求后但是未渲染视图前(即DispatcherServlet未向客户端发出响应)时调用,在该方法中对用户请求request进行处理。
③ afterCompletion()
这个方法在DispatcherServlet完全处理完请求后被调用,可以在方法中执行一些资源清理的工作。
【spingmvc.xml配置如下】
<mvc:interceptors> <!-- 配置自定义的拦截器 --> <bean class="com.web.springmvc.interceptors.FirstInterceptor"></bean> <!-- 配置拦截器(不)作用的路径 --><!-- <mvc:interceptor>--><!-- <mvc:exclude-mapping path="/emps"/>--><!-- <mvc:mapping path="/emps"/>--><!-- <bean class="com.web.springmvc.interceptors.SecondInterceptor"></bean>--><!-- </mvc:interceptor>--> <!-- 配置 LocaleChanceInterceptor --> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"></bean> </mvc:interceptors>
【代码示例如下:】
public class FirstInterceptor implements HandlerInterceptor{ /** * 该方法在目标方法之前被调用. * 若返回值为 true, 则继续调用后续的拦截器和目标方法. * 若返回值为 false, 则不会再调用后续的拦截器和目标方法. * * 可以考虑做权限. 日志, 事务等. */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("[FirstInterceptor] preHandle"); return true; } /** * 调用目标方法之后, 但渲染视图之前. * 可以对请求域中的属性或视图做出修改. */ @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("[FirstInterceptor] postHandle"); } /** * 渲染视图之后被调用. 释放资源 */ @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("[FirstInterceptor] afterCompletion"); }}
【配置拦截器作用路径】
使用<mvc:mapping/> or <mvc:exclude-mapping/>
指定拦截器的作用路径。
<mvc:interceptors> <!-- 配置自定义的拦截器 --> <bean class="com.atguigu.springmvc.interceptors.FirstInterceptor"></bean> <!-- 配置拦截器(不)作用的路径 --> <mvc:interceptor> <mvc:mapping path="/emp"/> <bean class="com.atguigu.springmvc.interceptors.SecondInterceptor"/><!-- <mvc:exclude-mapping path="/emps"/>--> </mvc:interceptor> <!-- 配置 LocaleChanceInterceptor --> <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor"></bean> </mvc:interceptors>
当有两个拦截器时,执行顺序如下:
[FirstInterceptor] preHandle[SecondInterceptor] preHandle@ModelAttribute 方法执行list method execute...[SecondInterceptor] postHandle[FirstInterceptor] postHandle[SecondInterceptor] afterCompletion[FirstInterceptor] afterCompletion
如果第二个拦截器的preHandle返回false:
[FirstInterceptor] preHandle[SecondInterceptor] preHandle[FirstInterceptor] afterCompletion
不会执行目标方法!
执行完第二个拦截器的preHandle之后,直接执行了第一个拦截器的afterCompletion!!
0 0
- SpringMVC
- springmvc
- SpringMVC
- SpringMVC
- springMvc
- springMVC
- springmvc
- springMVC
- springMVC
- springmvc
- SpringMVC
- SpringMVC
- springMvc
- springmvc
- springmvc
- SpringMVC
- Springmvc
- springmvc
- Android 蓝牙开发(五)OPP接收文件
- 山东第五届acm省赛总结:
- 【解决】virtualbox导入虚拟机后不能联网的问题
- 数据结构――堆的基本概念及其操作
- 关于python将文本文档以列表方式出现,末尾\n的意思。
- SpringMVC
- oracle--过滤和排序
- Digital Studio
- 剑指offer-39.平衡二叉树
- STL之map::find方法的使用小例子
- Hadoop学习笔记3、Hadoop环境搭建及测试
- 《javascript dom编程艺术》学习笔记
- 第七届蓝桥杯大赛个人赛(软件类)决赛真题
- WIfi