springmvc 拦截器_Springmvc学习(六)拦截器

过滤器和拦截器的区别

过滤器

  • servlet规范中的一部分,任何用servlet的工程都可以使用
  • 拦截web资源,如禁止访问地址,禁止访问图片等
  • 对request,response进行一些设置或过滤,如过滤非法字符,非法url
  • 全局设置,或者根据url设置

拦截器

  • springmvc的一部分,只有使用了springmvc才可以使用
  • 只拦截访问的控制器方法,多用于权限管理、日志服务。(因为它只能针对控制器方法做出逻辑,无法控制静态资源),不同方法可以有不同逻辑

核心区别:拦截器是AOP思想的具体应用

实际上过滤器能做的拦截器也能做,一般过滤器只是用来过滤url资源和设置编码,过滤器更多像从多个Servlet的service()方法里抽取的通用代码,通过使用Filter可以实现更好的复用

5353785a738e2426a2bfe0f798012bc4.png

自定义拦截器

1.实现HandlerInterceptor接口

2.重写接口方法

3.配置xml文件

public class MyInterceptor implements HandlerInterceptor {
    /*
    在请求处理的方法之前执行
    如果返回true就执行下一个拦截器
    如果返回false就不执行下一个拦截器,也就终止执行了
     */
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        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("=============清理==============");
    }
}
    <mvc:interceptors>
    <!-- 使用 bean 定义一个 Interceptor,直接定义在 mvc:interceptors 下面的 Interceptor 将拦截所有的请求 -->
        <mvc:interceptor>
            <!-- 定义在 mvc:interceptor 下面的 Interceptor,表示对特定的请求进行拦截 -->
            <mvc:mapping path="/hello"/>
            <bean class="com.hjc.interceptor.MyInterceptor"/>
        </mvc:interceptor>
    </mvc:interceptors>

fc2230d7875ebcc3de7e5305d992b43b.png

接口方法

preHandle

进行一些前置初始化操作或者是对当前请求做一个预处理,也可以在这个方法中进行一些判断来决定请求是否要继续进行下去。当它返回为false时,表示请求中断。

postHandle

在控制器中的方法调用之后执行,但是它会在DispatcherServlet进行视图返回渲染之前被调用,所以我们可以在这个方法中对控制器处理之后的ModelAndView对象进行操作。postHandle方法被调用的方向跟preHandle是相反的,也就是说,先声明的Interceptor的postHandle方法反而会后执行。

afterCompletion

该方法将在整个请求结束之后,也就是在DispatcherServlet渲染了对应的视图之后执行,这个方法的主要作用是用于进行资源清理的工作。

8591751efecbb66856bf53cecf8f0c8b.png

用户登录页面

即用户本身的首页必须要进行登录,若用户未登录进入首页则会跳转到用户登录页面。该逻辑就可以使用拦截器实现

8516274ddc59ed32d6505befd1775bc3.png

总结

拦截器是AOP思想的运用,实际上业务逻辑也可以用控制器实现,只是它可以作为控制器的扩展,不需要修改控制器的代码可以添加新的功能,这点的理解比较重要

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值