JavaWeb之Listener监听器

1.什么是监听器?

(1)监听器是Servlet规范中的一员。在Servlet中,所有的监听器接口都是以“Listener”结尾。
(2)监听器中的方法不需要程序员手动调用,是发生某个特殊事件之后被服务器调用的。(3)监听器仅仅是对三大域对象做相关的时间监听。

2.监听器有什么用?

(1)监听器实际上是Servlet规范留给我们javaweb程序员去执行某段代码的特殊时机。
(2)如果在特殊的时刻想执行一段代码,你需要想到使用对应的监听器。

3.监听器的分类

web中定义八个监听器接口作为监听器器的规范,这八个接口按照不同的标准可以形成不同的分类;
(1)按监听的对对象划分:
①applicationֿ域监听器: ServletContextListener、ServletContextAttributeListener;
②sessionֿ域监听器:HttpSessionListener、HttpSessionAttributeListener、 HttpSessionBindingListener、HttpSessionActivationListener;
③requestֿ监听器:ServletRequestListener、ServletRequestAttributeListener ;
(2)按监听的事件分:
ֿ①域对象的创建和销毁监听器:ServletContextListener、HttpSessionListener、ServletRequestListener;
②域对象数据增删改事件监听器:ServletContextAttributeListener、 HttpSessionAttributeListener、ServletRequestAttributeListener;
③其他监听器:HttpSessionBindingListener、HttpSessionActivationListener;

3.Servlet规范中提供了哪些监听器?

3.1 application域监听器

(1)ServletContextListener:监听ServletContext对象的创建与销毁。

public interface ServletContextListener extends EventListener {
    public default void contextInitialized(ServletContextEvent sce) {
	// 这个方法是在ServletContext对象被创建的时候调用
    }
    public default void contextDestroyed(ServletContextEvent sce) {
    // 这个方法是在ServletContext对象被销毁的时候调用
    }
}

(2)ServletContextAttributeListener:监听ServletContext中属性的添加、移除和修改。
①attributeAdded(ServletContextAttributeEvent scab):向ServletContext中添加属性时调用
②attributeRemoved(ServletContextAttributeEvent scab):向ServletContext中移除属性时调用
③attributeReplaced(ServletContextAttributeEvent scab):当ServletContext中的属性被修改时调用

3.2 session域监听器

(1)HttpSessionListener:监听HttpSession对象的创建和销毁

public interface HttpSessionListener extends EventListener {
    public default void sessionCreated(HttpSessionEvent se) {
     // session创建的时候被调用
    }
    public default void sessionDestroyed(HttpSessionEvent se) {
   // session销毁的时候被调用
    }
}

(2)HttpSessionAttributeListener
该监听器监听的是session域中数据的变化。只要数据变化,则执行相应的方法。主要监测点在session域对象上。

public interface HttpSessionAttributeListener extends EventListener {
    public default void attributeAdded(HttpSessionBindingEvent se) {
    // 向session域中存储数据的时候,该方法被WEB服务器调用
    }
    public default void attributeRemoved(HttpSessionBindingEvent se) {
   // 将session域中存储的数据删除的时候,该方法被WEB服务器调用
    }
    public default void attributeReplaced(HttpSessionBindingEvent se) {
   // session域中某个数据被替换的时候,该方法被WEB服务器调用
    }
}

(3)HttpSessionBindingListener
● 该监听器不需要使用@WebListener进行标注。
● 假设User类实现了该监听器,那么User对象在被放入session的时候触发“绑定”事件,User对象从session中删除的时候,触发
”解绑“事件。

@Data
public class User implements HttpSessionBindingListener {
    @Override
    public void valueBound(HttpSessionBindingEvent event) {
        // 绑定数据时调用
    }
    @Override
    public void valueUnbound(HttpSessionBindingEvent event) {
		// 解绑数据时调用
    }
    // 构造方法, Getter/Setter方法
    private String username;
    private Integer password;
}

(4)HttpSessionIdListener
● session的id发生改变的时候,监听器中的唯一一个方法就会被调用。
(5)HttpSessionActivationListener
● 监听session对象的钝化和活化的。
● 钝化:session对象从内存存储到硬盘文件。
● 活化:从硬盘文件把session恢复到内存。

3.3 request域监听器

(1)ServletRequestListener

public interface ServletRequestListener extends EventListener {
    public default void requestDestroyed (ServletRequestEvent sre) {
    // request对象销毁时间点被调用
    }
    public default void requestInitialized (ServletRequestEvent sre) {
    // request对象创建时间点被调用
} }

(2)ServletRequestAttributeListener

4.实现一个监听器的步骤

以ServletContextListener为例:
(1)第一步:编写一个类比如MyServletContextListener实现ServletContextListener接口。并且实现里面的方法。

void contextInitialized(ServletContextEvent event)
void contextDestroyed(ServletContextEvent event)

(2)第二步:在web.xml文件中对ServletContextListener进行配置,如下:

<listener>
  <listener-class>com.bjpowernode.javaweb.listener.MyServletContextListener</listener-class>
</listener>

● 当然,第二步也可以不使用配置文件,也可以用注解,例如:@WebListener
● 注意:所有监听器中的方法都是不需要javaweb程序员调用的,由服务器来负责调用。当某个特殊的事件发生
(其实就是某个时机到了)之后,被web服务器自动调用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值