过滤器(Filter):
能够完成筛选不需要数据的工具(东西).
1.什么是过滤器
生活中:净水器,香烟过滤嘴,滤纸,丈母娘,收费站等.------->单向的.
Web中:过滤器其实就是服务端的一个程序(程序的最小单元就是类).
在Web开发中,过滤器其实就是一个Web组件(Servlet/Filter/Listener),其实就是一个特殊的类.
一个类实现javax.servlet.Servlet接口:--->Servlet类.
一个类实现javax.servlet.Filter接口:----->Filter类.
2.过滤器的作用:
过滤器可以对所有的请求或者响应做拦截操作.
- 1:以常规的方式调用资源(Servlet/JSP);
- 2:利用修改过的请求信息调用资源;
- 3:调用资源之后,但在响应到客户端之前,对响应做出修改;
- 4:阻止当前资源调用,代之转到其他资源.
![](https://img.haomeiwen.com/i1128757/461ecf53a1f9534e.png)
Filter开发和使用
过滤器的开发和Servlet非常相似:(类比学习)
1.开发Servlet:
1):自定义一个类(XxxServlet),实现于javax.servlet.Servlet接口(继承于HttpServlet类).
2):在web.xml中做配置,告诉Tomcat来帮我管理这一个类(负责了该类的生命周期).:@WebServlet("/xxx")
<servlet>
<servlet-name>XxxServlet</servlet-name>
<servlet-class>XxxServlet类的全限定名</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>XxxServlet</servlet-name>
<!--向外暴露一个资源名称,目的:让客户端通过该资源名称来访问服务端对应的一个Servlet-->
<url-pattern>/xxx</url-pattern>
</servlet-mapping>
2.开发Filter:
1):自定义一个类(XxxFilter,Xxx表示功能名),实现于javax.servlet.Filter接口.
2):在web.xml中做配置,告诉Tomcat来帮我管理这一个类(负责了该类的生命周期).:@WebFilter("/hello.jsp")
<filter>
<filter-name>XxxFilter</filter-name>
<filter-class>XxxFilter类的全限定名</filter-class>
</filter>
filter-mapping>
<filter-name>XxxFilter</filter-name>
<!--表示:当前Filter只对哪些资源做过滤/拦截操作,只对hello.jsp做拦截-->
<url-pattern>/hello.jsp</url-pattern>
</filter-mapping>
3.Filter的生命周期方法:
- 1):void init(FilterConfig config): 初始化方法
- 2):void doFilter(ServletRequest request, ServletResponse response, FilterChain chain):执行过滤的方法(每一次请求都会执行过滤)
- 3):void destroy():销毁方法
执行的流程:
在启动Tomcat服务器的时候,就会执行构造器和init方法.
构造器--->init方法 -----> ( doFilter方法 )N次------->destroy方法
chain:链,链条,多个链的节点组合而成.
FilterChain:过滤器链,多个过滤器按照一定的顺序排列在一起. FilterChain.doFilter(req,resp):放行(放行给下一个Filter或资源)
![](https://img.haomeiwen.com/i1128757/f733a26b3b0a8369.png)
4.Filter映射细节:
-
1):多个Filter共存的时候,拦截的先后顺序由谁来决定?
由<filter-mapping>的配置先后顺序来决定. -
2):Filter的对哪些资源做过滤.
<url-pattern>被过滤的资源名称</url-pattern>
方式 | 作用域 |
---|---|
<url-pattern>/hello.jsp</url-pattern> | 只对/hello.jsp做过滤. |
<url-pattern>/*</url-pattern> | 对所有的资源做过滤操作. |
<url-pattern>/system/*</url-pattern> | 只对以/system/打头的资源做过滤. |
<url-pattern>*.do</url-pattern> | 只对以.do结尾的资源做过滤 |
-
3):可以通过<init-param>元素来给当前Filter配置初始化参数.
通过FilterConifg对象.getInitParameter(String name)来获取初始化参数. -
4):Servlet,Filter,Listener都属于Web组件.
一般的,先配置监听器,再配置过滤器,最后配置Servlet. - 5):<filter-mapping>中的子元素<dispatcher>表示对哪些操作执行过滤.
<!-- 缺省情况:REQUEST -->
<dispatcher>REQUEST</dispatcher>
<!-- 对请求转发做拦截 -->
<dispatcher>FORWARD</dispatcher>
<!-- 对请求包含做拦截 -->
<dispatcher>INCLUDE</dispatcher>
<!-- 出错之后再跳转到全局的结果视图之前做拦截 -->
<dispatcher>ERROR</dispatcher>
请求编码过滤器:CharacterEncodingFilter
![](https://img.haomeiwen.com/i1128757/dbee454bda25b6a5.png)
![](https://img.haomeiwen.com/i1128757/3c9ae142947d31dd.png)
![](https://img.haomeiwen.com/i1128757/bd16172038d092f7.png)
![](https://img.haomeiwen.com/i1128757/c0995a988f07cf6e.png)
上述编码过滤器,没问题.但是却把字符编码写死了.
解决方案:把字符编码作为Filter的初始化参数来配置.
![](https://img.haomeiwen.com/i1128757/ca67f22879e4918e.png)
![](https://img.haomeiwen.com/i1128757/873f00049aee5272.png)
登录验证过滤器:CheckLoginFilter
![](https://img.haomeiwen.com/i1128757/5ce3ae97d357f691.png)
![](https://img.haomeiwen.com/i1128757/283612ef2354d11b.png)
![](https://img.haomeiwen.com/i1128757/5ae29c81079bde76.png)
![](https://img.haomeiwen.com/i1128757/5b285b2d94d9b387.png)
![](https://img.haomeiwen.com/i1128757/c9b2009d1ef43630.png)
屏蔽敏感字过滤器:ContentFilter
![](https://img.haomeiwen.com/i1128757/150ff405ba932620.png)
![](https://img.haomeiwen.com/i1128757/d17670cca8737e7f.png)
上图在Servlet类中调用了FilterUtil的filter方法,完成对参数
字符串的敏感字过滤功能.
从正确与否上分析,没问题.但是,违背了责任分类的原则.
解决方案:使用过滤器来解决.
![](https://img.haomeiwen.com/i1128757/35741b828fb9d5a2.png)
上述方式,可以完成敏感字过滤,但是改变了获取请求参数的机制.放弃.
![](https://img.haomeiwen.com/i1128757/9f3bf0fe3b62f339.png)
![](https://img.haomeiwen.com/i1128757/459d2238cdd84de7.png)
我们需要解决的问题是啥:敏感字过滤.
为什么需要做这件事情:在原生的HttpServletRequest中的getParameter方法不支持敏感字过滤.
所以,得出结论,我们需要完成的: 让请求对象中的getParameter方法拥有敏感字过滤的功能.
目标:在不改变原有类的基础之上,对某一个方法做增强.
解决方案:
1):继承方式,覆盖需要增强的方法.------->子类出现爆炸式增强.
2):组合方式.--->包装设计模式(装饰设计模式:decorator)
装饰设计模式的作用:在不改变原有类的基础之上,对某一个对象做增强.
IServletRequerst接口: 模拟 ServletRequest接口.
DefaultServletRequestImpl类: 模拟 ServletRequest接口的实现类.
提供String getParameter(String name):并返回一个固定的值.
![](https://img.haomeiwen.com/i1128757/ddbbf946602533c0.png)
监听器
1.事件驱动编程:
简单地说就是你点什么按钮(即产生什么事件),电脑执行什么操作(即调用什么函数)。
事件驱动编程中核心对象:
1):事件源:谁发出事件通知,发出消息;也就是事件主体,比如按钮;
2):事件名称:发出什么样的通知的名称,比如鼠标到我头上了,我被别人点了一下;
3):事件响应函数:谁对这个这个事件感兴趣,当这个事件发生时要执行什么样的操作;
4):事件对象:一般来说,当事件发生时,会产生一个描述该事件的具体对象,包含事件相关信息。
调戏事件: 某一天,在大街上,张三看到一个美女,很美,很美,在美女的脸上点击了一下,美女给了张三一巴掌.
2.Web常见监听器:
监听request,session,ServletContext对象.
1):监听作用域对的创建和销毁.
ServletRequestListener:
HttpSessionListener:
ServletContextListener:监听服务器的启动和关闭.
2):监听作用域对象的属性的添加/删除/替换操作.(attributeAdded/attributeRemoved/attributeReplaced)
ServletRequestAttributeListener:
HttpSessionAttributeListener:
ServletContextAttributeListener:
开发监听器:对哪一种事件感兴趣,就实现哪一个事件对应的接口.
监听器没有自己的初始化参数,只能使用全局的初始化参数.
<context-param>
<param-name></param-name>
<param-value></param-value>
</context-param>
网友评论