标签:class 注解 包含 index port body Servle 标签 统一
web 中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。
一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符等功能。
① web.xml 配置
② 注解方式配置
1 import javax.servlet.*;
2 import javax.servlet.annotation.WebFilter;
3 import java.io.IOException;
4
5 @WebFilter("/*")
6 public class FirstFilter implements Filter {
7 public void destroy() {
8 }
9
10 public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
11 System.out.println("filterDemo1被执行了....");
12 // 放行操作
13 chain.doFilter(req, resp);
14 }
15
16 public void init(FilterConfig config) throws ServletException {
17
18 }
19
20 }
(1)注解配置
在类上添加 @WebFilter() 即可,里面填写访问所要拦截的资源的路径。
(2)web.xml 配置
1 <filter>
2 <filter-name>demo1</filter-name> // filter 的名称
3 <filter-class>cn.ks.web.filter.FilterDemo1</filter-class> // 完整的类名
4 </filter>
5 <filter-mapping>
6 <filter-name>demo1</filter-name>
7 <!-- 拦截路径 -->
8 <url-pattern>/*</url-pattern>
9 </filter-mapping>
(1)执行过滤器
(2)执行要放行的资源
(3)回来执行过滤器放行代码下面的代码
(1)init 方法:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次,一般用于加载资源。
(2)doFilter 方法:每一次请求被拦截资源时,会执行。执行多次
(3)destory 方法:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次,一般用于释放资源。
(1)拦截路径配置
1. 具体资源路径: /index.jsp 只有访问index.jsp资源时,过滤器才会被执行
2. 拦截目录: /admin/* 访问/user下的所有资源时,过滤器都会被执行
3. 后缀名拦截: *.jsp 访问所有后缀名为jsp资源时,过滤器都会被执行
4. 拦截所有资源: /* 访问所有资源时,过滤器都会被执行
(2)拦截方式配置:资源被访问的方式
注解配置:
设置 dispatcherTypes 属性
属性名 | 解释 |
REQUEST | 默认值。浏览器直接请求资源 |
FORWARD | 转发访问资源 |
INCLUDE | 包含访问资源 |
ERROR | 错误跳转资源 |
ASYNC | 异步访问资源 |
web.xml 配置:
设置 <dispatcher></dispatcher>标签,在里面填入上面的值即可。
(1)执行顺序:如果有两个过滤器:过滤器1和过滤器2
① 过滤器1
② 过滤器2
③ 资源执行
④ 过滤器2
⑤ 过滤器1
(2)过滤器先后顺序问题
① 注解配置:
规则:按照类名的字符串比较规则比较,值小的先执行。
如: AFilter 和 BFilter,AFilter就先执行了。
② web.xml 配置:
规则: <filter-mapping>谁定义在上边,谁先执行
标签:class 注解 包含 index port body Servle 标签 统一
原文地址:https://www.cnblogs.com/niujifei/p/11627551.html