当前位置:首页 > 文章列表 > 文章 > java教程 > Java自定义请求拦截器实现教程

Java自定义请求拦截器实现教程

2025-07-28 18:28:43 0浏览 收藏

在Java Web开发中,**自定义请求拦截器**是提升代码可维护性和系统可扩展性的关键技术。通过Spring的`HandlerInterceptor`接口或更底层的`javax.servlet.Filter`,开发者可以在请求处理前后执行身份校验、日志记录、参数修改等操作,将安全、日志等横切关注点与核心业务逻辑分离。本文详细介绍了如何使用Spring的`HandlerInterceptor`实现请求拦截,包括`preHandle`、`postHandle`、`afterCompletion`三个方法的应用,以及如何在配置类中注册拦截器并设置拦截路径。同时,也简要介绍了`javax.servlet.Filter`在字符编码、会话管理等方面的应用。合理利用自定义请求拦截器,能够构建结构清晰、职责分明的Web应用,避免代码重复,提高开发效率。

自定义请求拦截器在Java Web开发中至关重要。它允许开发者在请求真正被处理前执行诸如身份校验、日志记录或参数修改等操作,将横切关注点(如安全、日志)与核心业务逻辑分离,提升代码的可维护性与系统的可扩展性。1. 通过Spring的HandlerInterceptor接口,可以在preHandle方法中实现请求前处理;2. 在postHandle中进行视图渲染前的数据操作;3. 在afterCompletion中完成资源清理;4. 必须在配置类中注册拦截器并设置拦截路径;5. 若需更底层控制,也可使用javax.servlet.Filter,但其粒度较粗,适用于字符编码、会话管理等场景。总之,合理使用拦截器有助于构建结构清晰、职责分明的Web应用。

如何在Java中使用自定义请求拦截器 Java处理请求前置过滤逻辑

在Java里,想在请求真正被处理前做点什么,比如校验用户身份、记录日志,或者干脆改改请求参数,自定义请求拦截器就是那个你一直在找的利器。它能让你把那些横切关注点(cross-cutting concerns)集中管理,而不是让代码里到处都是重复的判断逻辑,让整个系统既干净又高效。

如何在Java中使用自定义请求拦截器 Java处理请求前置过滤逻辑

要说在Java里实现请求前置过滤,方法还真不少,但最常用、也最符合现代Web开发习惯的,莫过于Spring框架提供的HandlerInterceptor。当然,如果你在更底层的Servlet容器层面,javax.servlet.Filter也是个经典选项。

我们先聊聊HandlerInterceptor,因为它在Spring MVC应用里几乎是标配。你只需要实现这个接口,然后重写它的几个方法:

如何在Java中使用自定义请求拦截器 Java处理请求前置过滤逻辑
  1. preHandle(HttpServletRequest request, HttpServletResponse response, Object handler): 这是最常用的,在请求进入Controller方法之前执行。如果返回true,请求会继续向下传递;如果返回false,请求就会被中断,后续的拦截器和Controller都不会执行。
  2. postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView): 在Controller方法执行后,但在视图渲染之前执行。你可以在这里对ModelAndView进行操作,比如添加一些公共数据。
  3. afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex): 在整个请求处理完成,也就是视图渲染完毕后执行。通常用于资源清理,比如关闭数据库连接或者释放线程资源,哪怕Controller抛了异常,这个方法也照样会执行。

实现起来大概是这样:

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class MyAuthInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 假设这里做个简单的身份验证
        String token = request.getHeader("X-Auth-Token");
        if (token == null || !token.equals("valid-token-123")) {
            response.setStatus(HttpServletResponse.SC_UNAUTHORIZED); // 401 Unauthorized
            response.getWriter().write("{\"error\": \"Unauthorized\"}");
            response.getWriter().flush();
            return false; // 中断请求
        }
        System.out.println("请求通过认证: " + request.getRequestURI());
        // 可以在这里把用户信息存到request attribute里,方便后续Controller使用
        request.setAttribute("currentUser", "admin");
        return true; // 继续处理请求
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        // 可以在这里记录请求处理时间,或者给视图添加一些公共数据
        if (modelAndView != null) {
            modelAndView.addObject("appName", "MyAwesomeApp");
        }
        System.out.println("Controller执行完毕,准备渲染视图: " + request.getRequestURI());
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        // 请求处理完成,无论成功失败都会执行
        if (ex != null) {
            System.err.println("请求处理异常: " + request.getRequestURI() + ", 异常信息: " + ex.getMessage());
        } else {
            System.out.println("请求处理流程全部结束: " + request.getRequestURI());
        }
        // 资源清理等
    }
}

光有拦截器实现还不够,你还得告诉Spring去哪里注册它,以及它应该拦截哪些路径。通常是在Spring的配置类里:

如何在Java中使用自定义请求拦截器 Java处理请求前置过滤逻辑
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new MyAuthInterceptor())
                .addPathPatterns("/api/**") // 拦截 /api/ 下的所有请求
                .excludePathPatterns("/api/public/**"); // 但排除 /api/public/ 下的请求
        // 你可以注册多个拦截器,它们会按照添加的顺序依次执行preHandle
        // registry.addInterceptor(new AnotherInterceptor()).addPathPatterns("/admin/**");
    }
}

至于javax.servlet.Filter,它更像是Web容器层面的东西,比Spring Interceptor更早介入请求生命周期。你实现Filter接口,重写doFilter方法,然后通过@WebFilter注解或web.xml配置。它能做的事情和拦截器有些重叠,但粒度更粗,通常用于字符编码、GZIP压缩、会话管理等。Spring Interceptor则更专注于Spring MVC的请求处理流程。选择哪个,看你的具体需求和所处的技术栈吧。

为什么我们真的需要自定义请求拦截器?

你可能会想,不就是些前置处理嘛,直接在Controller方法里写不就行了?或者用AOP也能搞定啊。话是没错,但自定义请求拦截器自有它不可替代的价值,尤其是在构建复杂系统的时候。

它能帮你把那些“横切关注点”剥离出来。什么叫横切关注点?就是那些散落在系统各个角落,但又和核心

好了,本文到此结束,带大家了解了《Java自定义请求拦截器实现教程》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

为HTML标签添加可访问关联,主要通过使用ARIA属性和语义化标签来实现。以下是几种常见方法:1.使用语义化HTML标签语义化标签本身就能提供一定的可访问性,因为它们向屏幕阅读器传达了内容的结构和意义。:用于可点击的操作。:表示导航区域。:表示页面的主要内容。、:表示页面的头部和尾部。、:表示独立的内容块。-Home-About2.使用aria-labelledby和aria-describedb为HTML标签添加可访问关联,主要通过使用ARIA属性和语义化标签来实现。以下是几种常见方法:1.使用语义化HTML标签语义化标签本身就能提供一定的可访问性,因为它们向屏幕阅读器传达了内容的结构和意义。:用于可点击的操作。:表示导航区域。:表示页面的主要内容。、:表示页面的头部和尾部。、:表示独立的内容块。-Home-About2.使用aria-labelledby和aria-describedb
上一篇
为HTML标签添加可访问关联,主要通过使用ARIA属性和语义化标签来实现。以下是几种常见方法:1.使用语义化HTML标签语义化标签本身就能提供一定的可访问性,因为它们向屏幕阅读器传达了内容的结构和意义。:用于可点击的操作。:表示导航区域。:表示页面的主要内容。、:表示页面的头部和尾部。、:表示独立的内容块。-Home-About2.使用aria-labelledby和aria-describedb
Python天气应用开发教程:API调用全解析
下一篇
Python天气应用开发教程:API调用全解析
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    514次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    499次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • iTerms:一站式法律AI工作台,智能合同审查起草与法律问答专家
    iTerms
    iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
    8次使用
  • 脉络洞察AIGC:生命科学企业级解决方案,智能知识管理与合规创作
    脉络洞察AIGC
    脉络洞察AIGC是生命科学行业专属的企业级AI解决方案,深度整合知识库,实现内容创作、合规审核、智能问答全流程闭环,确保信息真实可溯源,助力医药企业降本增效,强化合规。
    5次使用
  • Joker:全栈可视化智能开发平台,赋能开发者高效构建应用
    Joker
    Joker 是一款全栈可视化智能开发平台,通过可视化操作、低代码逻辑编排和 AI 辅助,旨在降低开发门槛、提升开发效率,并兼顾开发灵活性与系统稳定性。支持从快速原型搭建到全功能系统落地,为开发者和企业提供全流程开发支持。
    5次使用
  • SEO  CodeCV 简历:互联网求职必备,高效定制你的专属简历
    CodeCV简历
    SEO CodeCV 简历是一款专为互联网从业者打造的简历制作工具,提供高度自定义编辑、AI 智能辅助和多格式适配功能,解决排版繁琐、模板固化等痛点,助你高效制作一份专业且个性化的简历。
    5次使用
  • 高效智能标书制作平台 - 神卷标书,助您轻松中标
    神卷标书
    神卷标书,专注标书制作,提供智能招标解析、AI智能生成、在线协作等功能,覆盖标书制作全流程,助您高效、专业地完成标书制作,提升中标率。
    0次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码