SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。

过滤器与拦截器的区别:拦截器是AOP思想的具体应用。

过滤器

  • servlet规范中的一部分,任何java web工程都可以使用
  • 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截

拦截器

  • 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
  • 拦截器只会拦截访问的控制器方法, 如果访问的是jsp/html/css/image/js是不会进行拦截

 

新建一个module。添加web项目,并引入springmvc的配置,并简单测试一下web项目和springmvc的正确性

  测试代码如下:

@RestController
//注意和Controller的区别,使用@Controller会交给视图解析器
public class TestSpringMVC {
    @GetMapping("/test")
    //注意和RequestMapping的区别 get方式来请求
    public String  Test1(){
        return "ok";
    }
}

java 接口如何拦截请求地址_mvc

 

 

 ==============================公共部分说完了================================================

开始说拦截器Interceptor

  想要自定义拦截器,必须实现 HandlerInterceptor 接口

    写一个实现HandlerInterceptor接口的类,并重写方法

public class MyInterceptor implements HandlerInterceptor {

    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //return false;  表示不放行,不执行下一个拦截器,或者拦住请求不让进了
        System.out.println("===这是一个执行请求前的拦截====");
        return  true;
    }

    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("===这是一个执行请求后的拦截====");
    }

    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("====清理====");
    }
}

   将这个实现HandlerInerceptor接口的类注册到SpringMVC中,并说明清楚这个拦截器所拦截的路径是什么

<mvc:interceptors>
        <!--可以配置多个拦截器-->
        <mvc:interceptor>
            <!--表示这个实现HandlerInterceptor的MyInterceptor类要拦截/下的所有请求-->
            <mvc:mapping path="/**"/>
            <bean class="com.chen.configer.MyInterceptor"/>
        </mvc:interceptor>
        <mvc:interceptor>
            <!--表示这个拦截/admin/下的所有请求-->
            <mvc:mapping path="/admin/**"/>
            <bean class="com.chen.configer.MyInterceptor"/>
        </mvc:interceptor>
    </mvc:interceptors>

  测试结果:

  

java 接口如何拦截请求地址_java_02

 

   我们一般只写拦截前就可以。后面是拦截日志

   现在有一个例子:

    我们只有在登录上的时候,才会允许我们访问到应用的首页。如果没有登录的话,除非是点击登录,否则我们都只会跳转到登录页面。

    我们可以在职工成功登录后,在controller层给session赋值。

@RequestMapping("/login")
   public String login(HttpSession session, String username, String pwd) throws Exception {
       // 向session记录用户身份信息
       System.out.println("接收前端==="+username);
       session.setAttribute("user", username);
       return "success";
   }

   所以我们就可以在拦截器里面这么写

package com.kuang.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;

public class LoginInterceptor implements HandlerInterceptor {

   public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws ServletException, IOException {
       // 如果是登陆页面则放行  获取这个请求的url
       System.out.println("uri: " + request.getRequestURI());
       if (request.getRequestURI().contains("login")) {         //如果这个请求的url中包含有login
           return true;
      }

       HttpSession session = request.getSession();

       // 如果用户已登陆也放行
       if(session.getAttribute("user") != null) {
           return true;
      }

       // 用户没有登陆跳转到登陆页面
       request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
       return false;
   }
}