web.xml过滤器 - filter

本文详细解析了web.xml中的过滤器功能,介绍了过滤器在Web应用中的生命周期、工作原理及配置方式。涵盖过滤器的实例化、初始化、过滤和销毁阶段,以及请求、转发、包含和错误四种拦截方式。

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

web.xml 过滤器 — 函数回调,指责链模式

1、 Filter作用 
当客户端发出Web资源的请求时,Web服务器根据应用程序配置文件web.xml设置的过滤规则,能够在一个request到达servlet之前预处理request,也可以在离开servlet时处理response。 —— filter实际是一个servlet chaining(servlet 链)

  • 在servlet被调用之前截获;

  • 在servlet被调用之前检查servlet request;

  • 根据需要修改request头和request数据;

  • 在servlet被调用之后截获.

  • 根据需要修改response头和response数据;

2、 过滤器生命周期的四个阶段:

  1. 实例化:Web容器在部署Web应用程序时对所有过滤器进行实例化。Web容器回调它的无参构造方法。

  2. 初始化:实例化完成之后,马上进行初始化工作。Web容器回调init()方法。

  3. 过滤:请求路径匹配过滤器的URL映射时。Web容器回调doFilter()方法——主要的工作方法。

  4. 销毁: Web容器在卸载Web应用程序前,Web容器回调destroy()方法。

3、 过滤器接口介绍

  • init(用来初始化)

  • dofilter(用来执行具体的操作) 
    此方法是由Servlet容器提供给开发者的,用于对资源请求过滤链的依次调用,通过FilterChain调用过滤链中的下一个过滤器,如果是最后一个过滤器,则下一个就调用目标资源。

  • destory(用来销毁)

4、拦截方式

  • request过滤器(默认):只有直接访问该目标资源时执行。包括:在地址栏中直接访问、表单提交、超链接、重定向

  • forward过滤器:转发访问执行过滤器。包括RequestDispatcher#forward()方法,标签都是转发访问;

  • include过滤器:包含访问执行过滤器。包括RequestDispatcher#include()方法,标签都是包含访问;

  • error过滤器:配置,出现该异常代码时,执行过滤器。

     1 <filter>
     2         <filter-name>patronliFilter</filter-name>//定义名字  
     3         <filter-class>com.servlet.DemoFilter</filter-class>//实现类  
     4 </filter>  
     5 <filter-mapping>
     6         <filter-name>DemoFilter</filter-name>  
     7         <url-pattern>/*</url-pattern>  
     8         <!-- 过滤器拦截规则:request过滤器,include过滤器,forward过滤器,error过滤器 -->
     9         <dispatcher>REQUEST</dispatcher>  
    10         <dispatcher>FORWARD</dispatcher>  
    11 </filter-mapping>  
    12 <!-- 如果想要配置多个拦截器,可以依次向下写 -->
     1 import javax.servlet.Filter;        //过滤器接口
     2 import javax.servlet.FilterChain;   //过滤器链接口
     3 import javax.servlet.FilterConfig;  //过滤器配置接口,getInitParameter方法用于获取web.xml中的初始化参数
     4 
     5 public class DemoFilter implements Filter{
     6     protected FilterConfig config;    
     7     protected String encoding;
     8 
     9     @Override //初始化的方法
    10     public void init(FilterConfig config) throws ServletException {
    11        this.config=config;
    12        this.encoding = config.getInitParameter("encoding"); //通过init-param设置参数,在init中取得
    13     }
    14 
    15     @Override //执行过滤的方法
    16     public void doFilter(ServletRequest arg0, ServletResponse arg1,
    17             FilterChain arg2) throws IOException, ServletException {
    18         request.setCharacterEncoding(encoding);
    19         System.out.println("Do...before..");  
    20         chain.doFilter(request, response); //由该方法进入下一过滤链。(filter拦截栈,后进先出)
    21         System.out.println("Do..after...");  
    22     }
    23 
    24     @Override //销毁的方法
    25     public void destroy() {
    26     }
    27 }

    引用:web.xml之过滤器详解

    引用:JavaWeb过滤器和监听器详解

 

转载于:https://www.cnblogs.com/kiqi/p/10454765.html

### SSM框架中的配置文件及其关系 #### 1. **web.xml** `web.xml` 是 Java Web 应用程序的部署描述符,用于定义应用程序的整体结构和初始化参数。它是整个项目的入口点。 - 定义 `DispatcherServlet` 的映射路径,负责拦截所有 HTTP 请求并将它们转发到 Spring MVC 控制器。 - 配置监听器(Listener),例如 `ContextLoaderListener`,用于加载全局上下文 `applicationContext.xml` 或其他类似的 XML 文件。 - 设置过滤器Filter),如字符编码过滤器,确保请求和响应的编码一致性。 ```xml <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/applicationContext.xml</param-value> </context-param> <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> ``` 此部分通过 `ContextLoaderListener` 初始化全局上下文,并由 `DispatcherServlet` 加载特定于 Spring MVC 的配置[^1]。 --- #### 2. **spring-mybatis.xml** 该文件主要用于 MyBatis 和 Spring 的集成,配置数据源、事务管理器以及 SQL Session 工厂。 - 数据源 (`DataSource`) 使用第三方库(如 Druid、C3P0)实现数据库连接池。 - 配置事务管理器 (`TransactionManager`) 来管理事务。 - 创建 `SqlSessionFactory` 并将其与 MyBatis 映射文件关联。 ```xml <!-- 数据源 --> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </bean> <!-- 事务管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!-- SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mapperLocations" value="classpath:mapper/*.xml" /> </bean> <!-- Mapper 扫描 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.example.mapper" /> </bean> ``` 此部分实现了 MyBatis 和 Spring 的无缝集成,使得 DAO 层可以通过注解或接口方式访问数据库[^2]。 --- #### 3. **spring-mvc.xml** 这是 Spring MVC 的核心配置文件,主要关注前端控制器的行为和视图解析。 - 组件扫描仅限于 Controller 类型的 Bean。 - 配置视图解析器以指定 JSP 页面的位置和扩展名。 - 启用对静态资源的支持以及其他高级功能。 ```xml <context:component-scan base-package="com.ssm.controller"> <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> <mvc:default-servlet-handler/> <mvc:annotation-driven/> ``` 这部分专注于处理用户的请求并返回相应的视图[^1]。 --- #### 4. **mybatis-config.xml** MyBatis 的核心配置文件,通常包含通用设置和插件声明。 - 配置缓存机制。 - 指定日志记录工具。 - 添加自定义类型处理器或其他扩展组件。 ```xml <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 缓存设置 --> <settings> <setting name="cacheEnabled" value="true"/> <setting name="lazyLoadingEnabled" value="true"/> </settings> <!-- 日志记录 --> <typeAliases> <package name="com.example.model"/> </typeAliases> <!-- 插件 --> <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"/> </plugins> </configuration> ``` 此文件提供了 MyBatis 运行所需的底层支持,而具体的 SQL 映射则交由单独的 Mapper 文件完成[^3]。 --- #### 配置关系总结 1. **web.xml** 负责启动容器并加载全局上下文和 DispatcherServlet。 2. **spring-mybatis.xml** 提供了持久层所需的数据源、事务管理和会话工厂。 3. **spring-mvc.xml** 处理业务逻辑和视图渲染。 4. **mybatis-config.xml** 则作为 MyBatis 的基础配置文件,补充了额外的功能选项。 这些文件相互协作,共同构建了一个完整的 SSM 架构应用。 --- #### 常见问题及解决方法 1. 如果服务无法找到对应的 Bean,则需确认是否正确注册了相关组件扫描范围或手动定义了 Bean 实例[^4]。 2. 当遇到数据库操作异常时,请检查 `sqlSessionFactory` 是否成功加载了正确的 Mapper 文件位置。 3. 若页面显示错误提示未找到视图名称,请验证视图解析器前缀和后缀是否匹配实际目录结构。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值