filter 过滤器
1.1概念
web中的过滤器:当服务器请求资料时,过滤器可以将请求拦截下来,完成一些特殊的功能1.2过滤器的作用
一般用于完成一些通用的操作。如:登录验证,统一编码处理,敏感字符过滤2.快速入门
步骤
- 定义一个类实现接口Filter
- 复写方法
- 配置拦截路径:1.注解 2.web.xml
注解配置过滤器
@WebFilter("/*")//配置拦截路径 *代表访问所有资源之前都会访问该过滤器
public class fliter1 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("我被执行了");
//放行
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
public void destroy() {
}
}
Web.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<filter>
<filter-name>filter1</filter-name>
<filter-class>com.blb.com.fliter1</filter-class>
</filter>
<filter-mapping>
<filter-name>filter1</filter-name>
<!-- 拦截路径-->
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
过滤器配置
1.拦截路径配置
具体资源路径:/index.jsp 只有访问index.jsp时,过滤器才会被执行
拦截目录:/user/* 访问/user下的资源时过滤器才会被执行
后缀名拦截: *.jsp 只有访问后缀为.jsp资源时过滤器才会被执行
拦截所有资源 / * 访问所有资源时过滤器才会被执行
2.拦截路径配置:资源被访问的方式
- 注解配置
设置dispatcherTypes属性
1. REQUEST:默认值,浏览器直接请求资源
2.FORWARD:转发访问资源
3.INCLUDE:包含访问资源
4.ERROR: 错误跳转资源
5.SAYNC: 异步访问资源
@WebFilter(value = "/one.jsp",dispatcherTypes ={ DispatcherType.FORWARD,DispatcherType.REQUEST})//两种方式同时使用
public class fliter2 implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("filter2");
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
public void destroy() {
}
}
2.web.xml配置
设置dispatcher 标签即可