拦截器是什么?
Spring MVC 的拦截器(Interceptor)与 JavaServlet 的过滤器(Filter)类似,它主要用于拦截用户的请求并做相应的处理,通常应用在权限验证、记录请求信息的日志、判断用户是否登录等功能上。
通过 HandlerInterceptor 接口的定义方式实现拦截
SpringMVC定义了拦截器的接口HandlerInterceptor该接口中定义了三个方法,这三个方法的调用时在springMVC框架内部完成的,调用这三个方法的时候,其参数的值也是从框架内部传递进来的。
-
boolean preHandle 预处理方法,实现处理器方法的预处理,就是在处理器方法执行之前这个方法会被执行,相当于拦截了处理器方法,狂阿基会传递请求和响应对象给该方法,第三个参数为被拦截的处理器方法。如果preHandle方法返回true表会死继续流程(如调用下一个拦截器或处理器方法),返回false表示流程中断。不会继续调用其他的拦截器或处理方放,此时我们就需要通过response来响应; -
void postHandle 后处理方法,实现处理器方法的后处理,就是在处理器方法调用完成,但在渲染试图之前,该方法被调用,此时我们可以通过modelAndView(模型和试图对象)对模型数据处理货试图进行处理。 -
afterCompletion 整个请求处理完毕,即在试图渲染完毕时该方法执行。
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
return false;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
preHandle( ): 该方法在控制器的处理请求方法前执行,其返回值表示是否中断后续操作,返回 true 表示继续向下执行,返回 false 表示中断后续操作。 postHandle( ): 该方法在控制器的处理请求方法调用之后、解析视图之前执行,可以通过此方法对请求域中的模型和视图做进一步的修改。 afterCompletion( ): 该方法在控制器的处理请求方法执行完成后执行,即视图渲染结束后执行,可以通过此方法实现一些资源清理、记录日志信息等工作。
拦截器的实现
- 编写一个类,继承 HandlerInterceptorAdapter
package com.wang.ssm.util;
import com.wang.ssm.model.Admin;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class LoginInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle");
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("postHandle");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion");
}
}
- 注册拦截器(就是在Springmvc中启动这个拦截器)
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<mvc:exclude-mapping path="/login/login"/>
<mvc:exclude-mapping path="/css/**"/>
<mvc:exclude-mapping path="img/**"/>
<mvc:exclude-mapping path="js/**"/>
<mvc:exclude-mapping path="/**.html"/>
<bean id="demo" class="com.wang.ssm.util.LoginInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
● < mvc:interceptors >: 该元素用于配置一组拦截器。这个里面可以配置多个< mvc:interceptor > ● < mvc:interceptor >: 该元素用于定义指定路径的拦截器。 ● < mvc:mapping >: 该元素是 < mvc:interceptor > 的子元素,用于配置拦截器作用的路径,该路径在其属性 path 中定义。path 的属性值为 /** 时,表示拦截所有路径,值为 /gotoTest 时,表示拦截所有以 /gotoTest 结尾的路径。 ● < mvc:exclude-mapping >: 如果在请求路径中包含不需要拦截的内容,就用这个进行配置。
需要注意的是,< mvc:interceptor > 元素的子元素必须按照 < mvc:mapping…/ >、< mvc:exclude-mapping…/ >、< bean…/ > 的顺序配置。 上一篇:>>> Spring MVC的文件上传
|