目录
1.拦截器
【前言】
过滤器的作用是保护请求的服务器资源,在请求资源被执行之前,如果请求地址符合拦截范围,则会先执行过滤器。过滤器的执行时机,是在 Servlet 之前执行的。但是在使用了SpringMVC 后,Servlet 只有一个了,也就是 DisptcherServlet。
而如果我们仍然使用过滤器来完成请求的拦截,但过滤器是在 Servlet 之前执行的,过滤器会拦截 DispatcherServlet 所有的请求。那么,如果我 们有部分请求不想被拦截,怎么办呢?
1.1 概念
SpringMVC 给出了拦截器来实现单元方法的拦截,拦截器的执行是在 DispatcherServlet 之后和单元方法之前的,这样我们就可以在单元方法被之前对请求进行自定义的拦截处理了。 【注意】只有 URL 匹配到了控制单元,拦截器才能生效
1.2 使用拦截器
(1)创建拦截器
通过实现 HandlerInterceptor 接口,或继承 HandlerInterceptor 接口的实现类(如 HandlerInterceptorAdapter)来定义。这里我们主要使用实现 HandlerInterceptor 接口的方式创建。
package com.wollo.interceptor;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MyInterceptor3 implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler){
/**
* 作用:
* 拦截单元方法的请求
* 执行时机:
* 在DispatcherServlet之后,单元方法之前
* @param request 封装了此次请求的请求数据的request对象
* @param response 此次请求的响应对象
* @param handler HandlerMethod,HandlerMethod对象中存储了此次请求的单元方法的Method对象
* @return 返回true表示放行继续执行单元方法,返回false表示拦截。
* @throws Exception
*/
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
/**
* 作用:
* 对作用域中的数据进行一些操作,比如:敏感词汇的脱敏
* 执行时机:
* 在单元方法之后执行,转发的页面资源之前
* @param request 封装了此次请求的请求数据的request对象
* @param response 此次请求的响应对象
* @param handler HandlerMethod,HandlerMethod对象中存储了此次请求的单元方法的Method对象
* @param modelAndView: 包含了Mode