Spring MVC框架中的拦截器详细使用过程

加油,新时代打工人!

Spring MVC详细环境配置和入门
Spring MVC 响应数据和结果视图
SpringMVC实现三种文件上传的方式
Spring MVC的异常处理和友好页面

实现之前把Spring MVC环境配置完成,参考以上文章


目录结构
在这里插入图片描述

1. 拦截器的概述

  1. SpringMVC框架中的拦截器用于对处理器进行预处理和后处理的技术。
  2. 可以定义拦截器链,连接器链就是将拦截器按着一定的顺序结成一条链,在访问被拦截的方法时,拦截器链
    中的拦截器会按着定义的顺序执行。
  3. 拦截器和过滤器的功能比较类似,有区别
    1. 过滤器是Servlet规范的一部分,任何框架都可以使用过滤器技术。
    2. 拦截器是SpringMVC框架独有的。
    3. 过滤器配置了/*,可以拦截任何资源。
    4. 拦截器只会对控制器中的方法进行拦截。
  4. 拦截器也是AOP思想的一种实现方式
  5. 想要自定义拦截器,需要实现HandlerInterceptor接口。

2.自定义拦截器

代码如下:

package com.itboy.interceptor;

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

        import javax.servlet.http.HttpServletRequest;
        import javax.servlet.http.HttpServletResponse;

/**自定义拦截器
 * @author wh
 * @date 2021年11月19日22:03
 */
public class MyInterceptor1 implements HandlerInterceptor{
    /**
     *
     * preHandle 方法 预处理 在controller之前拦截
     * 可以用登录 登录成功跳转
     * return true放行,执行下一个拦截器,若没有,择执行controller
     * return false 不放行,后面controller不执行,但可以使用 request和response 调到其他页面
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("MyInterceptor执行了1,,,,前111");
        // request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
        return true;
    }

    /**后执行方法
     *  postHandle 方法是在controller之后执行
     *  可以处理
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("MyInterceptor1执行了,,,,后111");
        //  request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
    }

    /** 可以释放资源
     *  afterCompletion 方法是在所有页面执行后运行
     * @param request
     * @param response
     * @param handler
     * @param ex
     * @throws Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("MyInterceptor1执行了,,,,最后运行111");
    }
}

springmvc.xml配置拦截器

    <!--配置拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--要拦截的方法
            /**:拦截所有-->
            <mvc:mapping path="/user/*"/>
            <!--不要拦截的方法-->
            <!--<mvc:exclude-mapping path=""></mvc:exclude-mapping>-->
            <!--配置拦截对象-->
            <bean class="com.itboy.interceptor.MyInterceptor1"></bean>
        </mvc:interceptor>
    </mvc:interceptors>

3. usercontroller控制器

package com.itboy.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;


/**
 * @author wh
 * @date 2021年11月19日21:27
 */
@Controller
@RequestMapping(value = "/user")
public class UserController {
    @RequestMapping("/interecptor")
    public String interecptor() {
        System.out.println("interecptor方法执行了...");
        return "success";
    }
}

一个拦截器执行过程

1.首先请求页面经过拦截器,自定义类MyInterceptor1的preHandle方法返回ture,后面执行UserController,若放回false,则不执行后面UserController
2.postHandle方法是在UserController 执行完成后执行
3.afterCompletion方法在所有页面执行完成后执行,也就是最后执行,可以释放资源,比如流(stream)等

4.配置第二个拦截器

把自定义拦截器在复制一份即可

package com.itboy.interceptor;

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

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**自定义拦截器
 * @author wh
 * @date 2021年11月19日22:03
 */
public class MyInterceptor2 implements HandlerInterceptor{
    /**
     *
     * preHandle 方法 预处理 在controller之前拦截
     * 可以用登录 登录成功跳转
     * return true放行,执行下一个拦截器,若没有,择执行controller
     * return false 不放行,后面controller不执行,但可以使用 request和response 调到其他页面
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("MyInterceptor2执行了,,,,前222");
      // request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
        return true;
    }

    /**
     *  后执行方法postHandle 方法是在controller之后执行
     *  可以处理
     * @param request
     * @param response
     * @param handler
     * @param modelAndView
     * @throws Exception
     */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("MyInterceptor2执行了,,,,后222");
      //  request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request,response);
    }

    /**
     * 可以释放资源 success执行后 afterCompletion 方法是在所有页面执行后运行
     * @param request
     * @param response
     * @param handler
     * @param ex
     * @throws Exception
     */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("MyInterceptor2执行了,,,,最后运行222");
    }
}

在springmvc.xml在配置一个拦截器

  <!--配置第二个拦截器-->
    <mvc:interceptors>
        <mvc:interceptor>
            <!--要拦截的方法
            /**:拦截所有-->
            <mvc:mapping path="/user/*"/>
            <!--不要拦截的方法-->
            <!--<mvc:exclude-mapping path=""></mvc:exclude-mapping>-->
            <!--配置拦截对象-->
            <bean class="com.itboy.interceptor.MyInterceptor2"></bean>
        </mvc:interceptor>

两个拦截器执行过程:

1.先执行第一个拦截器的preHandle(),在执行第二个preHandle()
2.然后执行控制器的方法
3. 执行第二个拦截器postHandle (),在执行第一个postHandle ()
4. 在执行第二个拦截器afterCompletion (),在执行第一个afterCompletion()

5.运行截图

在这里插入图片描述

6.github源码地址

https://github.com/itboywh/springmvc_day02_04_Interceptor

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hello World呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值