【SpringMVC学习笔记_5】拦截器

本文介绍了SpringMVC中的拦截器机制,包括在控制器方法执行前的preHandle、执行后的postHandle以及视图渲染完成后的afterCompletion三个关键方法。HandlerInterceptor接口的这三个方法允许开发者在不同阶段介入请求处理流程,实现如权限验证、日志记录等功能。

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


前言

springMVC提供了三种不同的拦截方法,分别用于拦截控制器Controller方法执行的三个不同阶段


SpringMVC中的拦截器需要实现HandlerInterceptor

@Component
public class FirstInterceptor implements HandlerInterceptor {
	//重写接口中的三个拦截方法
}

在SpringMVC的配置文件中进行配置

    <mvc:interceptor>
<!--    <bean class="com.cx.springmvc.interceptor.FirstInterceptor"></bean>-->
<!--    <ref bean="FirstInterceptor"></ref>-->
        <!-- 以上两种配置方式都是对DispatcherServlet所处理的所有的请求进行拦截 -->

        <mvc:mapping path="/**"/>
        <mvc:exclude-mapping path="/testExclude"/>
        <!--
    以上配置方式可以通过ref或bean标签设置拦截器,通过mvc:mapping设置需要拦截的请求,通过mvc:exclude-mapping设置需要排除的请求,即不需要拦截的请求
        -->
    </mvc:interceptor>

一、preHandle

拦截位置:控制器方法执行之前

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        return HandlerInterceptor.super.preHandle(request, response, handler);
    }

二、postHandle

拦截位置:控制器方法执行之后

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
    }

三、afterCompletion

拦截位置:视图渲染完成之后

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值