spring自定义拦截器
转:https://demo.winterchen.com/blog/article/44.html
在想了解拦截器在spring中的作用,我们首先要了解一下HTTP的请求执行链。
-
DispatcherServlet捕获每一个请求;
-
DispatcherServlet将接收到的URL和相应的Controller进行映射;
-
在请求到达相应的Controller之前拦截器会进行请求处理;
-
处理完成之后进行视图的解析;
-
返回视图。
在第3步中,也就是今天最重要的内容,在请求到达Controller之前,请求可以被拦截器处理,这些拦截器就像过滤器。只有当URL找到对应于它们的处理器时才会调用它们。在通过拦截器(拦截器预处理,其实也可以说前置处理)进行前置处理后,请求最终到达controller。之后,发送请求生成视图。但是在这之前,拦截器还是有可能来再次处理它(拦截器后置处理)。只有在最后一次操作之后,视图解析器才能捕获数据并输出视图。
处理程序映射拦截器基于org.springframework.web.servlet.HandlerInterceptor
接口。这个接口有三个方法
public interface HandlerInterceptor { //请求发送到Controller之前调用 default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } //请求发送到Controller之后调用 default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { } //完成请求的处理的回调方法 default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { } }
编写自定义的拦截器
要想编写自定义的拦截器,需要有两个步骤:
-
实现
HandlerInterceptor
接口和方法; -
将自定义拦截器添加到MVC中。
下面我们来实现一下代码:
首先我们创建一个类BaseInterceptor
/** * 实现HandlerInterceptor接口,自定义拦截器 */ @Component public class BaseInterceptor implements HandlerInterceptor { private static final Logger LOGGE = LoggerFactory.getLogger(BaseInterceptor.class); //实现前置方法 @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception { String uri = request.getRequestURI(); LOGGE.info("UserAgent: {}", request.getHeader(USER_AGENT)); LOGGE.info("用户访问地址: {}, 来路地址: {}", uri, IPKit.getIpAddrByRequest(request)); //拦截器处理用户权限 if (uri.startsWith("/admin") && !uri.startsWith("/admin/login")) { response.sendRedirect(request.getContextPath() + "/admin/login"); return false; } return true; } @Override public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception { //这个方法可以往request中添加一些公共的工具类给前端页面进行调用 } @Override public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception { //当请求处理完成调用 } }
以上的自定义拦截器实现类中,我们实现了HandlerInterceptor
接口,并且实现了三个方法:preHandle
、postHandle
、afterCompletion
。
在实际的应用中呢,我们常常可以在请求处理的前置方法preHandle
中进行权限的验证,postHandle
后置方法在实际的使用当中可以往request中添加一些公共的工具类给前端页面进行调用。
创建一个类WebMvcConfig
实现WebMvcConfigurer
接口
/** * 向MVC中添加自定义组件 * Created by Donghua.Chen on 2018/4/30. */ @Component public class WebMvcConfig implements WebMvcConfigurer { @Autowired private BaseInterceptor baseInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(baseInterceptor); } }
这个类的主要作用就是将我们刚才自定义的拦截器组件添加到MVC中去。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)