Java Web 监听器详解

一、监听器原理:

监听器就是一个实现特定接口的普通java程序,这个程序专门用于监听一个java对象的方法调用或属性改变,当被监听对象发生上述事件后,监听器某个方法将立即被执行。

java web 监听器详解

 

简单的说,被监听对象A中,关联着B对象。事件源A类对外提供一个方法,用于设置监听器对象BA类的某一实例变量中。在需要监听事件源的方法中,方法体的某一处先构造创建一个Event对象,将thisB与相关的动作封装进Event对象中,然后调用监听器B对象的doXXXX(event)方法,将事件对象传入方法实参中。

简单的类图示例:

java web 监听器详解

二、简介:

Servlet规范中定义了多种类型的监听器,它们用于监听的事件源分别为SerlvetConext,HttpSessionServletRequest这三个域对象。

Servlet规范针对这三个对象上的操作,又把这多种类型的监听器划分为三种类型:

1>监听三个域对象创建和销毁的事件监听器

2>监听域对象中属性的增加和删除的事件监听器

3>监听绑定到HttpSession域中的某个对象的状态的时间监听器。

a、如三个域对象的创建与销毁方法签名:

ServletRequestListener有以下两个方法

void requestDestroyed(ServletRequestEvent sre)  

void requestInitialized(ServletRequestEvent sre) 

HttpSessionListener有以下两个方法

void sessionCreated(HttpSessionEvent se) 

void sessionDestroyed(HttpSessionEvent se)  

ServletContextListener

void contextDestroyed(ServletContextEvent sce) 

void contextInitialized(ServletContextEvent sce)  

b、三个类型对象域中增、删、改的监听器(3个)

ServletContextAttributeListener

HttpSessionAttributeListener

ServletRequestAttributeListener

c、感知型监听器(2个):监听自己何时被帮到session上,何时解绑了;何时被钝化了,何时被活化了(序列化到某个存储设置中)

注意:这种监听器不需要注册。某个javabean实现这些接口后就可以监听何时被绑定、解绑或被激活或钝化。

HttpSessionBindingListener:实现该接口的类,能检测自己何时被Httpsession绑定,和解绑

HttpSessionActivationListener:实现该接口的类(要求些javabean必须是实现了Serializable接口的),能监测自己何时随着HttpSession一起激活和钝化。

三、Listenner的注册

Javaweb的这些特别的监听器注册比较简单,因为ServletRequestHttpSessionServletContext对象都是容器创建的,所以需要它们的监听器的话,只需要在应用的web-infoweb.xml里配置即可:

<listener>

<listener-class>com.test.listener.MyHttpSessionAttributeListener</listener-class>

<listener-class>com.test.listener.MyServletContextAttributeListener</listener-class>

<!--  多个实现相同的Listenner接口,在执行时是按web.xml注册出现的来决定。 -->

</listener>

注意:感知型监听器HttpSessionBindingListenerHttpSessionActivationListener不需要注册。

三、应用场景:

由于ServletRequestHttpSessionServletContext对象都是容器创建的,什么时候创建,用户都不知道。通过实现这些对象的监听器后,就可以得知了。比如:

1>ServletContextLintener监听器的contextInitialized方法中,进行应用级的资源初始化以便提高效率,在contextDestroyed方法中对应用级的资源进行释放。

2>又比如web应用中,会存在会话,通常的作法是将当前登录的用户存放在session会话中。那么如何统计在线人数话,如何显示出当前登录的用户呢。如何踢出某些已登录的用户呢。就可以通过HttpSessionAttributeListener监听器的attributeAdded方法。

等等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值