Filter
过滤器实际上就是对web资源进行拦截,做一些处理后再交给下一个过滤器或servlet处理
通常都 是用来拦截request进行处理的,也可以对返回的response进行拦截处理
使用
这里要注意,可以配置多个过滤器,以满足不同的需求
- 写一个自定义过滤器,实现 Filter 接口
public class CharSetFilter implements Filter{}
- 实现接口方法
//销毁的方法
public void destroy() {
}
//过滤方法 主要是对request和response进行一些处理,然后交给下一个过滤器或 chain.doFilter(req, resp);
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException {
Servlet处理 }
public void init(FilterConfig config) throws ServletException { /*初始化方法 接收一个FilterConfig类型的参数 该参数是对Filter的一些配置*/
}
- 在 web.xml 中配置
<filter>
<filter-name>过滤器名称</filter-name>
<filter-class>过滤器所在的路径</filter-class>
</filter>
<filter-mapping>
<filter-name>过滤器名称</filter-name>
<url-pattern>需要过滤的资源</url-pattern>
</filter-mapping>
使用场景
3.1如何防止用户未登录就执行后续操作
String name=(String)session.getAttribute("key");
if(name==null){
//跳转到登录⻚面
}
**3.2.**设置编码方式–统一设置编码
**3.3.**加密解密(密码的加密和解密)
**3.4.**非法文字筛选
**3.5.**下载资源的限制
过滤器的特点:在servlet之前(req之前)和之后(resp之后)都会被执行
Listener
感觉 Listener 有点 Listener 的味道
可以用来监听三个作用域:request、session、servletContext
相关概念
事件源:
被监听的对象(三个域对象 request、session、servletContext)
监听器:
监听事件源对象事件源对象的状态的变化都会触发监听器
注册监听器:
将监听器与事件源进行绑定
响应行为:
监听器监听到事件源的状态变化时所涉及的功能代码(程序员编写代码)
监听维度
第一维度
按照被监听的对象划分:ServletRequest域、HttpSession域、ServletContext域
第二维度
按照监听的内容分:监听域对象的创建与销毁的、监听域对象的属性变化的
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uD24ueRI-1620996266371)(/Users/faro_z/Library/Application Support/typora-user-images/image-20210514190417526.png)]
编写步骤
- 编写一个监听器类去实现监听器接口
- 覆盖监听器的方法
- 需要在web.xml中进行配置—注册
<listener>
<listener-class>监听器所在的路径</listener-class>
</listener>