[SpringMVC] SpringMVC拦截器

本文详细阐述了拦截器和过滤器的概念、实现方式及应用场景。重点介绍了如何使用拦截器解决Web应用中的乱码和权限验证问题,并对比了拦截器与过滤器之间的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作用

拦截器可处理Web应用中请求的一些通用性问题
共性问题在拦截器中处理,可以减少重复代码,便于维护

使用场景

处理所有请求的共同问题
1. 解决乱码问题
用户发送请求到达Controller之前进行拦截,对request中的参数设置编码
2. 解决权限验证问题
用户进行一些请求时,查看Session中是否有登陆信息,没有则跳转到登陆界面

过滤器

与过滤器的区别

  1. 拦截器只能拦截url
    拦截器Interceptor依赖于框架容器,基于反射机制,只过滤请求
  2. 过滤器还可拦截资源文件
    过滤器Filter依赖于Servelt容器,基于回调函数,过滤范围大,资源文件、url等

过滤器处理乱码问题

<!-- web.xml中设置 -->
<filter>
    <filter-name>encoding</filter-name>
    <filter-class>org.springframework.web.filter.CharaterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>utf8</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encoding</filter-name>
    <url-pattern>*</url-pattern>
</filter-mapping>

拦截器的实现

实现步骤

  1. 编写拦截器类实现HandleInterceptor接口
  2. 将拦截器注册进Spring MVC框架中
  3. 配置拦截器的拦截规则

例子

  1. 编写类

    public class TestInterceptor implements HandleInterceptor{
        //进入Controller之前调用
        //Object参数:被拦截的请求目标对象
        public boolean preHandle(HttpServletRequest req,HttpServletResponse resp,Object obj) throws Exception{
            //可提前对request,response进行处理
            req.setCharaterEncoding("utf-8"); //解决乱码问题
            if (req.getSession().getAttribute("user")==null) {
                //用户没有登录,拦截并跳转登录界面
                req.getRequestDispatcher("/login").forward(req,resp);
                return false;
            }
            return true; //true通过,不拦截;false不通过,拦截
        }
        //进行Controller之后的操作
        public void postHandle(HttpServletRequest req,HttpServeltResponse resp,Object obj,ModelAndView model) throws Exception {
            model.addObject("msg","拦截器发送属性给JSP");
            model.setViewName("/other"); //跳转到其他页面
        }
        //最后调用的方法,destory等操作
        public void afterCompletion(HttpServletRequest req,HttpServletResponse resp,Object obj,Exception excp) throws Exception{
    
        }
    } 
    
  2. 注册
    springmvc配置文件注册;配置文件中要有mvc的命名空间与编写规则的xsd文件

    <mvc:interceptors>
        <bean class="实现类的路径.类名"/>
    </mvc:interceptor> 
    
  3. 拦截规则

    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="url正则表达式"/> <!--拦截匹配的url-->
            <bean class=""></bean>
        </mvc:interceptor>
    </mvc:interceptor>
    

多个拦截器顺序

多个拦截器顺序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

geodoer

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

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

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

打赏作者

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

抵扣说明:

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

余额充值