基于SpringMVC配置拦截器
配置拦截器-interceptors
- 基于HandlerMapping,对请求实施拦截,根据业务需求,基于不同的HandlerMapping定义多个拦截器。
- HandlerInterceptor接口
- preHandle()
- postHandle()
- afterCompletion()
- springmvc支持自定义拦截器
- a. 写一个拦截器类:需要实现spring提供的拦截器接口或继承接口的实现类:HandlerInterceptorAdapter。
- b. 实现里面的方法。
- c. 在springmvc配置文件中配置:通过mvc标签完成。
代码示例我们测试用户是否登录,没有登录重定向到登录界面,登陆过则放行:
- 自定义拦截器类
public class MyInterceptor extends HandlerInterceptorAdapter {
/**
* 登录放行、没有登陆,进行登录
* 进入控制层的处理器方法前会先进入到此方法
* @param request
* @param response
* @param handler
* @return true 放行 false 禁止通行
* @throws Exception
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 获取用户对象,判断用户是否为空(登录)
User user = (User)request.getSession().getAttribute(Constants.USER_SESSION);
if (user != null){
return true;
}
response.sendRedirect(request.getContextPath()+"/login.jsp");
return false;
}
- 配置SpringMVC的配置文件,配置拦截器
<!--配置拦截器:拦截器只能对action请求起作用-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<!--不拦截登录-->
<mvc:exclude-mapping path="/login/login"/>
<bean class="cn.smbms.interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
补充:
-
拦截器是基于java的反射机制的,而过滤器是基于函数回调。
-
拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
-
拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
-
拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
-
在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
-
过滤器是在请求进入容器后,但请求进入servlet之前进行预处理的。请求结束返回也是,是在servlet处理完后,返回给前端之前。拦截器是在servlet容器之内的。
-
Tomeat容器——> Filter(过滤器)——> Servlet容器 ——> Interceptor(拦截器)——> Controller(控制层)