监听器Listener过滤器Filter总结

一、 监听器Listner

1. 监听器概述

监听器监听三大域,ServletRequest,HttpSession, ServletContext三大域,可以分别监听三大域的生命周期事件和属性事件,监听什么,就实现什么接口,覆写相关方法。当监听的事件发生改变时,会执行覆写的方法。

如:想要监听ServletContext域的属性添加事件和生命周期出生事件,编写MyServletContextListener类

  1. 实现ServletContextAttributeListener接口和ServletContextListener接口
  2. 覆写void attibuteAdded(ServletAttributeEvent event)方法和 void contextInitialized(ServletContxetEvent sce)方法。
  3. 在web.xml文件中部署监听器
<listener>
<listener-class>cn.itcast.listener.MyServletContextListener</listener-class>
</listener>
2. 监听器方法

由事件对象获得监听域对象
ServletContext servletContext = event.getServletConext();

由属性事件对象获得当前监听的域对象

3. 感知监听

1.HttpSession监听 :如JavaBean实现HttpSessionBindingListener接口,覆写以下两个方法,则可以监听javabean对象在session中的状态:

public void valueBound(HttpSessionBindingEvent event) 把监听器对象添加session中会调用监听器对象的本方法;
public void valueUnbound(HttpSessionBindingEvent event)方法,当把监听器对象移除到session中会调用监听器对象的本方法;

2.钝化 - HttpSessionActivationListener
Tomcat会在session从时间不被使用时钝化session对象,session中存储的对象也被纯化,当session被活化时,也会把session中存储的对象活化。

如果某个类实现了HttpSessionActiveationListener接口后,且实现Serializable接口当对象随着session被钝化和活化时,下面两个方法就会被调用:
public void sessionWillPassivate(HttpSessionEvent se):当对象感知被活化时调用本方法;
public void sessionDidActivate(HttpSessionEvent se):当对象感知被钝化时调用本方法;

二、 过滤器

1.什么是过滤器

过滤器JavaWeb三大组件之一,它与Servlet很相似!不它过滤器是用来拦截请求的,而不是处理请求的。

当用户请求某个Servlet时,会先执行部署在这个请求上的Filter,如果Filter“放行”(在doFilter()方法中添加chain.doFilter(request, response)),那么会继承执行用户请求的Servlet;如果Filter不“放行”,那么就不会执行用户请求的Servlet。

其实可以这样理解,当用户请求某个Servlet时,Tomcat会去执行注册在这个请求上的Filter,然后是否“放行”由Filter来决定。可以理解为,Filter来决定是否调用Servlet!当执行完成Servlet的代码后,还会执行Filter后面的代码。

Filter的三个方法:
l void init(FilterConfig):在Tomcat启动时被调用;
l void destroy():在Tomcat关闭时被调用;
l void doFilter(ServletRequest,ServletResponse,FilterChain):每次有请求时都调用该方法;

在这里插入图片描述

2.编写HelloFilter,对index.jsp进行拦截
  1. 实现Filter接口,覆写init(FilterConfig filterConfig),doFilter(ServletRequest request, ServletResponse response,FilterChain chain),destroy()方法。

不放行:

public class HelloFilter implements Filter {
	public void init(FilterConfig filterConfig) throws ServletException {}
	public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) throws IOException, ServletException {
		System.out.println("Hello Filter");
	}
	public void destroy() {}
}

放行:

public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain) throws IOException, ServletException {
	System.out.println("filter start...");
	chain.doFilter(request, response);
	System.out.println("filter end...");
}
  1. 在web.xml文件中部署Filter
<filter>
   <filter-name>helloFilter</filter-name>
   <filter-class>cn.itcast.filter.HelloFilter</filter-class>
</filter>
<filter-mapping>
   <filter-name>helloFilter</filter-name>
   <url-pattern>/index.jsp</url-pattern>
</filter-mapping>
3.FilterConfig

ServletContext getServletContext():获取ServletContext的方法;

4. FilterChain

void doFilter(ServletRequest,ServletResponse):放行!表示执行下一个过滤器,或者执行目标资源。可以在调用FilterChain的doFilter()方法的前后添加语句,在FilterChain的doFilter()方法之前的语句会在目标资源执行之前执行,在FilterChain的doFilter()方法之后的语句会在目标资源执行之后执行。

如果当前过滤器是最后一个过滤器,那么调用chain.doFilter()方法表示执行目标资源,如果不是最后一个过滤器,那么chain.doFilter()表示执行下一个过滤器的doFilter()方法。
.
执行顺序
一个目标资源可以指定多个过滤器,过滤器的执行顺序是在web.xml文件中的部署顺序。

5. 四种拦截方式

l REQUEST:直接访问目标资源时执行过滤器。包括:在地址栏中直接访问、表单提交、超链接、重定向,只要在地址栏中可以看到目标资源的路径,就是REQUEST;
l FORWARD:转发访问执行过滤器。包括RequestDispatcher#forward()方法、jsp:forward标签都是转发访问;
l INCLUDE:包含访问执行过滤器。包括RequestDispatcher#include()方法、jsp:include标签都是包含访问;
l ERROR:当目标资源在web.xml中配置为中时,并且真的出现了异常,转发到目标资源时,会执行过滤器。
如:

<filter-mapping>
	<filter-name>myfilter</filter-name>
	<url-pattern>/b.jsp</url-pattern>
	<dispatcher>REQUEST</dispatcher>
	<dispatcher>FORWARD</dispatcher>
</filter-mapping>
6. 过滤器的应用场景

执行目标资源之前做预处理工作,例如设置编码,这种试通常都会放行,只是在目标资源执行之前做一些准备工作;

通过条件判断是否放行,例如校验当前用户是否已经登录,或者用户IP是否已经被禁用;
在目标资源执行后,做一些后续的特殊处理工作,例如把目标资源输出的数据进行处理;

7. 案例
  1. 分ip统计网站的访问次数
  2. 粗粒度权限控制(拦截是否登录、拦截用户名admin权限)
  3. 解决全站字符乱码(POST和GET中文编码问题)
  4. 页面静态化
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
监听器Listener),过滤器Filter),拦截器(Interceptor)都是用于在软件系统中实现某种行为的组件。 监听器是一种可以监听特定事件并做出响应的组件。它可以捕获系统中发生的事件,比如用户请求、应用程序启动或关闭等,然后执行相应的操作。例如,一个Web应用程序可能会使用监听器来监听用户登录事件,并在用户登录成功时执行一些额外的逻辑。 过滤器是一种可以对输入和输出进行过滤和处理的组件。它可以拦截到达系统的请求和响应,并在它们传递给相应的处理组件之前或之后对其进行处理。过滤器常用于实现一些通用的功能,比如请求参数解析、身份验证、日志记录等。一个Web应用程序通常会使用过滤器来处理所有进入该应用程序的请求,以及所有从该应用程序返回的响应。 拦截器是一种可以拦截方法调用或消息传递并加入自定义逻辑的组件。它可以在方法调用前后执行额外的操作,比如日志记录、性能监测、事务管理等。拦截器常用于实现横切关注点(cross-cutting concerns),即与核心业务逻辑无关但需要在多个模块或层次上执行的功能。例如,在一个分布式系统中,拦截器可以用于在方法调用前后进行分布式事务管理。 总结来说,监听器过滤器和拦截器都是在软件系统中用于实现特定行为的组件。它们可以在某些事件发生时或某些操作执行前后进行拦截、处理或加入自定义逻辑。它们都可以用于增强系统的功能和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值