当前位置: 首页 > news >正文

Java过滤器的基本概念

概述

        Java 过滤器是 Java EE (Jakarta EE) 中的一种组件,用于在请求到达 Servlet 或 JSP 之前对其进行预处理,或者在响应返回客户端之前对其进行后处理。过滤器主要应用于以下场景:

  • 请求参数过滤和转换
  • 字符编码处理
  • 身份验证和授权
  • 日志记录
  • 压缩响应数据
  • 缓存控制

核心接口和方法

  1. init(FilterConfig config) - 初始化过滤器
  2. doFilter(ServletRequest request, ServletResponse response, FilterChain chain) - 执行过滤逻辑
  3. destroy() - 销毁过滤器
public class CharacterEncodingFilter implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {Filter.super.init(filterConfig);}@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {}@Overridepublic void destroy() {Filter.super.destroy();}
}

配置方式

过滤器可以通过以下方式配置:

        1.注解配置(Servlet 3.0+)

使用@WebFilter注解可以直接在过滤器类上配置过滤器,无需在 web.xml 中配置。别忘了在 Spring Boot 应用主类上添加@ServletComponentScan注解以启用 Servlet 组件扫描:

package com.cni23.filter;import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;/*** urlPatterns 匹配所有请求,/*拦截所有请求,可以填写具体请求路径*/
@WebFilter(urlPatterns = "/*",filterName = "CharacterEncodingFilter")
public class CharacterEncodingFilter implements Filter {private String encoding;/*** 初始化过滤器*/@Overridepublic void init(FilterConfig filterConfig) throws ServletException {String encoding = filterConfig.getInitParameter("encoding");if (encoding == null){encoding = "UTF-8";}}/*** 执行过滤器逻辑*/@Overridepublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {//获取请求HttpServletRequest request =(HttpServletRequest) servletRequest;request.setCharacterEncoding(encoding);servletResponse.setCharacterEncoding(encoding);servletResponse.setContentType("text/html;charset=utf-8");//filterChain:链//放行,继续执行下一个过滤器,如果没有过滤器,则执行目标资源filterChain.doFilter(servletRequest,servletResponse);}/*** 销毁过滤器*/@Overridepublic void destroy() {}
}

        2.web.xml 配置(传统方式)

<filter><filter-name>CharacterEncodingFilter</filter-name><filter-class>com.cni23.filter.CharacterEncodingFilter</filter-class></filter><filter-mapping><filter-name>CharacterEncodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping>

        3.Java 代码配置(Spring 等框架中常用,)

1)编写过滤规则

import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Enumeration;public class RequestLoggingFilter implements Filter {@Overridepublic void init(FilterConfig filterConfig) throws ServletException {// 初始化逻辑}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {HttpServletRequest httpRequest = (HttpServletRequest) request;// 记录请求信息System.out.println("Request URL: " + httpRequest.getRequestURL());System.out.println("Method: " + httpRequest.getMethod());// 记录请求头Enumeration<String> headerNames = httpRequest.getHeaderNames();while (headerNames.hasMoreElements()) {String headerName = headerNames.nextElement();System.out.println(headerName + ": " + httpRequest.getHeader(headerName));}// 继续请求处理链chain.doFilter(request, response);}@Overridepublic void destroy() {// 清理资源}
}

2)配置我们的过滤器

import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class FilterConfig {@Beanpublic FilterRegistrationBean<RequestLoggingFilter> loggingFilter() {FilterRegistrationBean<RequestLoggingFilter> registrationBean = new FilterRegistrationBean<>();// 设置过滤器实例registrationBean.setFilter(new RequestLoggingFilter());// 设置过滤器应用的URL模式registrationBean.addUrlPatterns("/api/*", "/secure/*");// 设置过滤器名称registrationBean.setName("requestLoggingFilter");// 设置过滤器执行顺序(值越小,优先级越高)registrationBean.setOrder(1);// 添加初始化参数registrationBean.addInitParameter("enabled", "true");return registrationBean;}
}

配置方式对比

  1. 注解配置

    • 优点:简洁、直观,与代码在一起,便于维护
    • 缺点:不够灵活,URL 模式等配置与代码耦合
  2. web.xml 配置

    • 优点:集中管理,配置与代码分离,适合复杂场景
    • 缺点:XML 文件可能变得庞大复杂,难以维护
  3. Java 代码配置

    • 优点:完全的编程控制,可以使用 Spring 的依赖注入
    • 缺点:需要了解 Spring 框架,配置相对复杂

具体使用哪一个可以根据自己的项目来决定。


文章转载自:

http://CZKAnbXV.wyfpc.cn
http://9OQLZx19.wyfpc.cn
http://pUmLIuTp.wyfpc.cn
http://Byioj5AO.wyfpc.cn
http://0UuJjU0O.wyfpc.cn
http://yvFYNPRt.wyfpc.cn
http://8m22K6Cq.wyfpc.cn
http://Yb2SMsCl.wyfpc.cn
http://A6VRQ4o2.wyfpc.cn
http://DQiCsSwP.wyfpc.cn
http://ia8DVCHe.wyfpc.cn
http://RNHaUskr.wyfpc.cn
http://XWVFUpRA.wyfpc.cn
http://LG22tktz.wyfpc.cn
http://Ora4x9Ym.wyfpc.cn
http://IQz7m3Ix.wyfpc.cn
http://n6eBiCnL.wyfpc.cn
http://SrHFScpU.wyfpc.cn
http://bPmgX7nF.wyfpc.cn
http://IRvE4jtL.wyfpc.cn
http://aBKDzzlV.wyfpc.cn
http://IGJcjvA1.wyfpc.cn
http://M265VbVT.wyfpc.cn
http://wZwoK9yo.wyfpc.cn
http://rKcVWbrr.wyfpc.cn
http://eRaE5pHN.wyfpc.cn
http://joK7mmlU.wyfpc.cn
http://iE4S7waC.wyfpc.cn
http://GeiF6xy1.wyfpc.cn
http://X9czCbTx.wyfpc.cn
http://www.dtcms.com/a/247835.html

相关文章:

  • 【PDF】常见纸张字体大小设置指南 / Common Paper Size Font Guidelines
  • 开源组件hive调优
  • 论文略读:Do Large Language Models Truly Understand Geometric Structures?
  • 产品推荐|一款具有单光子级探测能力的科学相机千眼狼Gloria 1605
  • python 爬虫,爬取某乎某个用户的全部内容 + 写个阅读 app,慢慢读。
  • PostgreSQL作为向量数据库
  • 高效账号信息管理工具,可安全随机生成密码
  • SQL力扣
  • Flotherm许可管理工具和软件
  • RAD:通过基于大规模 3DGS 的强化学习训练端-到-端驾驶策略
  • PCB 层压板的 Dk 和 Df 表征方法 – 第一部分
  • MATLAB | 如何使用MATLAB获取《Nature》全部绘图 (附23-25年图像)
  • 认识LinkedHashMap
  • MySQL 8.0 OCP 英文题库解析(十八)
  • 【android bluetooth 框架分析 04】【bt-framework 层详解 7】【AdapterProperties介绍】
  • 吃透 Golang 基础:函数
  • Markdown入门与语法汇总
  • 用电子垃圾DIY一个可调小电源(5-12V)
  • 【HarmonyOS Next之旅】DevEco Studio使用指南(三十三) -> 构建任务
  • linux学习慕课版 第一章 Linux 文件与目录学习笔记
  • WEBSOCKET研究
  • 深入剖析Redis高性能的原因,IO多路复用模型,Redis数据迁移,分布式锁实现
  • 【IEEE/EI/Scopus检索】2025年第六届模式识别与数据挖掘国际会议 (PRDM 2025)
  • ros导航原理
  • 如何在 Visual Studio Code 中配置SSH、Git 和 Copilot插件
  • 对象注入 BeanFactory 的操作 BeanFactoryPostProcessor , Spring boot
  • 20250613在Ubuntu20.04.6下编译Rockchip的RK3576原厂Android14的SDK【整理编译】
  • JVM GC 问题排查实战案例
  • CSS flex-basis 属性详解:功能、用法与最佳实践
  • EFK架构的数据安全性