JavaWeb-Filter编程详解

一、Filter介绍

  • 概念:Filter表示过滤器,是JavaWeb三大组件(Servlet、Filter、Listener)之一。
  • 过滤器可以把对web资源的请求拦截下来,做一些处理后再交给下一个过滤器或客户端。从而实现一些特殊的功能。
  • 过滤器一般完成一些通用操作,比如:自动登录、权限控制、统一编码格式设置、敏感字符过滤等。
    Filter工作流程图如下:

在这里插入图片描述

二、Filter开发步骤

1、定义类,实现Filter接口,并重写其所有方法

public class MyFilter implements Filter {
  	@Override  
    public void init(FilterConfig arg0) throws ServletException {  
    	// 初始化方法,接受一个 FilterConfig 的参数,该参数是对Filter的配置
    }  
    
    @Override  
    public void destroy() {  
    	// 销毁时调用
    }  
  
    @Override  
    public void doFilter(ServletRequest req, ServletResponse res,
                         FilterChain chain) throws ServletException, IOException {
    	// 过滤方法,对 Resquest 与 Response 对象进行处理,之后交给其他Filter或服务器端
    }  
}

2、在doFilter()方法中配置过滤方法,对request和response进行处理,最后放行

@Override  
public void doFilter(ServletRequest req, ServletResponse res,
						FilterChain chain) throws ServletException, IOException {
	HttpServletResponse response = (HttpServletResponse) res;
	System.out.println("过滤器执行---");
	response.setHeader("Access-Control-Allow-Origin", "*");
	...
	// 放行
	chain.doFilter(req, res);
}  

3、配置Filter拦截资源的路径,方法有2种。第一种使用@WebFilter注解;第二种在web.xml文件中进行配置

①在类上定义@WebFilter注解

@WebFilter(filterName = "myFilter", urlPatterns = {"/*"})
public class MyFilter implements Filter {}

②配置XML文件

<!--配置Filter类路径-->
<filter>
	<filter-name>myFilter</filter-name>
	<filter-class>com.tyt.filter.FilterDemo</filter-class>
</filter>
<!--配置myFilter拦截的Servlet的映射路径-->
<filter-mapping>
	<filter-name>myFilter</filter-name>
	<url-pattern>/*</url-pattern>
</filter-mapping>

三、Filter执行流程

1. Filter放行后访问对应资源,资源访问完成后,还会再次回到Filter中。
2. 回到Filter中,执行放行后的逻辑

在这里插入图片描述

四、Filter详细使用

1. Filter拦截路径配置

  • Filter可以根据需求,配置不同的拦截资源路径
  • 拦截具体资源/index.html,只有访问 index.html 时才会被拦截
  • 目录拦截/hello/*,访问 /hello 下的所有资源,都会被拦截
  • 后缀名拦截*.html,访问所有 html 文件均会被拦截
  • 拦截所有/*,访问所有资源,均会被拦截

2.过滤器链

  • 一个Web应用,可以配置多个过滤器,这多个过滤器被称为过滤器链

在这里插入图片描述

3.Filter执行顺序

1. 注解配置的Filter:
优先级按照过滤器的实现类类名(字符串)的自然排序。


2. xml配置的Filter:
按在web.xml中配置<filter-mapping>的顺序,从上到下执行。


3. 既有注解配置也有xml配置:
优先执行web.xml中配置的Filter。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java EE 项目的目录结构可以根据具体的需求进行灵活设计,但一般情况下,推荐使用以下的标准目录结构: ``` project ├── src │ ├── main │ │ ├── java │ │ │ └── com │ │ │ └── example │ │ │ ├── controller │ │ │ ├── dao │ │ │ ├── entity │ │ │ ├── service │ │ │ └── util │ │ ├── resources │ │ │ ├── mapper │ │ │ └── db.properties │ │ └── webapp │ │ ├── WEB-INF │ │ │ ├── classes │ │ │ ├── lib │ │ │ └── web.xml │ │ ├── css │ │ ├── js │ │ ├── images │ │ └── index.jsp │ └── test │ ├── java │ └── resources ├── target ├── pom.xml └── README.md ``` 其中,各个目录的作用如下: - `src/main/java`:存放项目的 Java 源代码,按照包名分层,一般包括 `controller`、`dao`、`entity`、`service` 和 `util` 等包; - `src/main/resources`:存放项目的配置文件和资源文件,一般包括数据库连接配置文件 `db.properties`、MyBatis 的 mapper 文件等; - `src/main/webapp`:存放 Web 应用的 Web 资源,包括 JSP 页面、CSS 样式表、JavaScript 脚本等; - `src/test/java`:存放项目的测试代码; - `src/test/resources`:存放测试代码所需要的资源文件; - `target`:存放编译后的 .class 文件、打包后的 .war 文件等; - `pom.xml`:Maven 项目管理工具的配置文件; - `README.md`:项目说明文件。 以上是一种常见的 Java EE 项目目录结构,但并不是唯一的标准。在实际开发中,可以根据项目的具体需求进行合理的调整和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值