spring 拦截器_[Spring-SpringMVC-MyBatis] 07- 拦截器

0cd775bed3d4e0aca95d566890b710a4.png

在学习拦截器之前,我们学习了过滤器以及AOP面向切面思想,

所以可以理解为拦截器是一个比过滤器更小更精准的过滤器,且作用于控制单元

过滤器

过滤器针对的是你的每一个请求

过滤器一共做3件事情

  • [1]到达目标资源之前的预处理操作
  • [2]执行下一个过滤器或者目标资源
  • [3]离开服务器之前的处理操作

拦截器

拦截器主要针对的就是控制单元,我们可以理解成拦截器就是一个细化的过滤器

拦截器实现的思想就是Spring AOP

a、切点--控制单元.

b、通知--拦截器的方法

c、织成切面

d4756927a11e2f93d1c8fbd97c988f7d.png

1.编写拦截器类 实现 HandlerInterceptor 接口 重写三个方法

1.1 preHandle 返回值是布尔类型的 若return true 即放行

执行的时机:

在进入控制单元方法之前

这个方法的返回值决定了是否继续执行控制单元的方法

  • 返回值是true --就进入控制单元继续执行
  • 返回值是false--就不会继续执行

即将执行控制单元中方法对象

e4aa3ba7e70b17a7948b10e212939b8b.png

作用:

82cf2b48f4fac9a6c0ba46526713a71f.png

dfd6080c2cd851f22df5286d7747aaf7.png

1.2 postHandle

执行的时机:

在数据处理之后进行处理

df2a30c35e99a8e8f70634960438178c.png

作用:

06cd62cbef5591497e928637432c0339.png

3a908e0a4744f474580e4e4a4746752e.png

66bb996d68c5b0d73de0263f296c9428.png

1.3 afterCompletion

执行的时机:

在进行页面渲染的时候

dd712c8ab60069c5388017c2ac4809da.png

作用

8822fe81b5f3b2ad9f0c76d55f359e61.png

679842063a7984b7b19f3ac7eab43088.png

2在applicationContext-mvc.xml中进行配置

v2-578194deebdea130a782799847a7dce7_b.jpg

3e64d3deb2be5ef66f46514373c6fabc.png
package com.lin.interceptor;

import org.apache.log4j.Logger;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

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

public class LogInterceptor implements HandlerInterceptor {
    private Logger logger = Logger.getLogger(LogInterceptor.class);

    /**
    * 在进入控制器方法前被调用的方法
    *
    * @param request 请求对象
    * @param response 响应对象
    * @param handler 被拦截的控制器方法
    * @return true表示允许访问, false表示终止访问. 如果返回false, 需要提示客户端
    * @throws Exception
    */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        logger.error("[日志拦截: 1] - preHandle - 控制器被调用前执行 - " + handler);
        return true;
    }

    /**
    * 控制器方法调用结束, 有返回结果之后, 调用postHandle方法
    *
    * @param request 请求对象
    * @param response 响应对象
    * @param handler 控制器方法
    * @param modelAndView 控制器方法返回的结果
    * @throws Exception
    */
    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        logger.error("[日志拦截: 2] - postHandle - 控制器调用后执行 - " + handler);
    }

    /**
    * 本次流程结束后会被调用的方法, 通常用于最终的异常处理
    *
    * @param request 请求对象
    * @param response 响应对象
    * @param handler 控制器方法
    * @param ex 异常对象
    * @throws Exception
    */
    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        logger.error("[日志拦截: 3] - afterCompletion - 流程结束 - " + handler);
    }
}

拦截器的原理

d4756927a11e2f93d1c8fbd97c988f7d.png

e4aa3ba7e70b17a7948b10e212939b8b.png

9da07dfbf4980a70f9289e8a1ae3fb38.png

ae8c382ec98da30497991d46fec7bb79.png

4d9558ba87c77bfbe281909e7219f1da.png

多重拦截器

先进后出,越后面的越先出

6c84d633dbc7459a28a091426990fd43.png

细节

拦截具体和拦截所有

dd39d19fe8940dfacca1c83695a461f6.png

389aa0a3783f22681d8968e8a3290765.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值