1 继承HandlerInterceptor
参考博客:http://jinnianshilongnian.iteye.com/blog/1670856
http://elim.iteye.com/blog/1750680
在SpringMVC 中定义一个Interceptor 非常简单,主要有两种方式,第一种方式是要实现Spring 的HandlerInterceptor 接口,或者是实现了HandlerInterceptor 接口的类,比如Spring 已经提供的实现了HandlerInterceptor 接口的抽象类HandlerInterceptorAdapter ;第二种方式是实现Spring的WebRequestInterceptor接口,或者是继承实现了WebRequestInterceptor的类。
package com.text.intercepter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class TextHandlerInterceptor implements HandlerInterceptor{
@Override
public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
// TODO Auto-generated method stub
System.out.println("3-----------执行afterCompletion");
}
@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2, ModelAndView arg3) throws Exception {
// TODO Auto-generated method stub
System.out.println("2-----------执行postHandle方法");
}
@Override
public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2) throws Exception {
// TODO Auto-generated method stub
System.out.println("1-----------执行preHandle方法");
return true;
}
}
SpringMVC中的配置:
<mvc:interceptors>
<!-- 使用bean定义一个Interceptor,直接定义在mvc:interceptors根下面的Interceptor将拦截所有的请求 -->
<mvc:interceptor>
<mvc:mapping path="/*"/>
<!-- 定义在mvc:interceptor下面的表示是对特定的请求才进行拦截的 -->
<bean class="com.text.intercepter.TextHandlerInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
拦截器的执行顺序是按声明的先后顺序执行的,先声明的拦截器中的preHandle方法会先执行,然而它的postHandle方法和afterCompletion方法却会后执行。
在mvc:interceptors标签下声明interceptor主要有两种方式:
(1)直接定义一个Interceptor实现类的bean对象。使用这种方式声明的Interceptor拦截器将会对所有的请求进行拦截。
(2)使用mvc:interceptor标签进行声明。使用这种方式进行声明的Interceptor可以通过mvc:mapping子标签来定义需要进行拦截的请求路径。
HandlerIntercept接口执行顺序:
正常执行顺序:
当preHandler返回fasle时:
2 各种拦截url的方式:
url-pattern有5种配置模式:
(1)/xxx:完全匹配/xxx的路径
(2)/xxx/*:匹配以/xxx开头的路径,请求中必须包含xxx。
(3)/*:匹配/下的所有路径,请求可以进入到action或controller,但是转发jsp时再次被拦截,不能访问jsp界面。
(4).xx:匹配以xx结尾的路径,所有请求必须以.xx结尾,但不会影响访问静态文件。
(5)/:默认模式,未被匹配的路径都将映射到刺servlet,对jpg,js,css等静态文件也将被拦截,不能访问。
3 拦截器的应用–登录。
3.1 拦截器继承自HandlerInterceptor,preHandle中从Session中查看有无该用户。
public class LoginInterceptor implements HandlerInterceptor{
private List<String> allowedPass;
public void setAllowedPass(List<String> allowedPass) {
this.allowedPass = allowedPass;
}
public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
}
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2, ModelAndView arg3) throws Exception {
}
public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
Object handler) throws Exception {
String url=request.getRequestURI().toString();
//先判断session中是否有
Object user=request.getSession().getAttribute("user");
if(user!=null){
return true;
}
for(String temp:allowedPass){
if(url.endsWith(temp)){
//当前存在用户,
return true;
}
}
//当前无该用户,返回到登录页面
response.sendRedirect(request.getContextPath()+"/login.jsp");
return false;
}
3.2 拦截器的配置:
<!-- 拦截器的配置 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- /** 拦截的路径及其子路径 -->
<mvc:mapping path="/**"/>
<bean class="cn.sxt.interceptor.LoginInterceptor">
<!-- 依赖注入,allowedPass在拦截器中为一个Set集合,List标签定义集合中的每个元素 -->
<property name="allowedPass">
<list>
<value>login.do</value>
</list>
</property>
</bean>
</mvc:interceptor>
</mvc:interceptors>
未完待续。。。