WEB三大组件:
Filter:过滤器
Listener:监听器
Sevelet:控制器
Fliter过滤器:
Web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。
过滤器的作用:
一般用于完成通过的操作。如:登录验证、统一编码处理、敏感字符过滤***。
快速入门:
1.步骤:
1.定义一个类,实现Filter接口
2.复写方法
3.配置拦截路径
2.代码:
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
System.out.println("doFilter.....");
filterChain.doFilter(servletRequest,servletResponse);
System.out.println("放行.....");
}
3.过滤器细节:
1.web.xml配置
<filter>
<filter-name>/demo</filter-name>
<filter-class>com.zcl.lmmb.FilterDemo</filter-class>
</filter>
<filter-mapping>
<filter-name>/demo</filter-name>
//拦截访问路径
<url-pattern>/*</url-pattern>
</filter-mapping>
2.过滤器执行流程
1.执行过滤器
2.执行释放后的资源
3.回来执行过滤器放行代码下边的代码。
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
//对request对象的请求消息进行增强
System.out.println("FilterDemo执行了.....");
filterChain.doFilter(servletRequest,servletResponse);
//对response对象的响应消息进行增强
System.out.println("FilterDemo返回了.....");
}
3.过滤器生命周期方法
服务器启动后,创建Filter对象,然后调用init方法,只执行一次。
doFilter每次拦截请求资源的时候都会执行。
destory:在服务器关闭后,Filter对象被销毁,会执行。只执行一次。
4.过滤器配置详情
1.拦截路径配置:
1.具体资源路径:/index.jsp,只有访问该资源,才被拦截
2.拦截目录:/user/*,访问/user下的所有资源时,才执行
3.后缀名拦截: *.jsp 访问后缀名为jsp资源时,才执行
4.拦截所有资源:/* 访问所有资源,过滤器都会执行。
2.拦截方式配置:资源被访问的方式
1.注解配置
设置:dispatcherTypes属性
1.REQUEST:默认值,浏览器直接请求资源
2.FORWARD:转发访问资源
3.INCLUDE:包含访问资源
4.ERROR:错误跳转资源
5.ASYNC:异步访问资源
2.web.xml配置
设置<dispatcher></dispatcher>标签即可
<filter-mapping>
<filter-name>/demo</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>
5.过滤器链(配置多个过滤器)
执行顺序:如果有两个过滤器:过滤器1和过滤器2
1.过滤器1先执行
2.过滤器2
3.资源执行
4.过滤器2回来执行
5.过滤器1回来执行
过滤器先后顺序问题:
1.注解配置:按照类名的字符串比较规则比较,值小的先执行。
如:AFilter和BFilter,先执行AFilter
2.web.xml配置:<filter-mapping>谁配置在上面,谁先执行。