1.为什么使用它?
有很多全站性的东西需要处理,例如乱码问题,通过过滤器统一进行过滤更简单
2.有什么用?
实现用户在访问某个目标资源之前,对访问的请求和响应进行拦截。简单说,就是可以实现web容器对某资源的访问前截获进行相关的处理,还可以在某资源向web容器返回响应前进行截获进行处理。
3.怎么用?
步骤1:先写一个类实现javax.servlet.Filter接口
步骤2:重写抽象方法
步骤3:在doFilter()方法中写处理代码,最后用FilterChain调用FilterChain.doFilter(req, resp)方法,表示可以执行后面的拦截器(如果有的话)
步骤3:进行配置,web.xml配置如下
1
2
3
4
5
6
7
8
9
10
11
12
|
<!-- 优先配置过滤器 ,过滤器应该在Servlet前面配置,并且过滤器之间有顺序 --> < filter > < filter-name >firstfilter</ filter-name > < filter-class >cn.hk.filter.FirstFilter</ filter-class > </ filter > < filter-mapping > < filter-name >firstfilter</ filter-name > <!-- 拦截访问资源 *表示拦截所以资源 --> < url-pattern >/*</ url-pattern > </ filter-mapping > |
4运用的场景?
1)实现URL级别的权限访问控制;
2)处理全站中文乱码问题;
3)实现自动登录;
4)过滤敏感词汇;
5) 压缩网页;
6)选择性让浏览器缓存;等等。
这几种功能的实现采用同样的原理,那就是使用包装模式或动态代理增强request或response对象的功能。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://blog.csdn.net/zuoan666/article/details/73555341