Listener

本文详细介绍了Servlet监听器的概念及其在监听ServletContext、HttpSession和ServletRequest创建与销毁中的作用。此外,还探讨了如何通过监听器来统计在线人数、管理数据库连接池及实现Spring的IOC容器。
Servlet监听器:Servlet规范中定义的一种特殊类,它用来监听四大域的三个:
监听ServletContext,HttpSession,ServletRequest的创建与销毁。
以及这三个对象的属性被修改的事件

监听类型主要分为三种:

1.监听域对象自身的创建和销毁。

ServletContext web应用被加载时创建,web应用被卸载时销毁,※是最常用的Listener。
常见使用举例:创建数据库连接池,读取web应用初始化参数,创建Spring的IOC容器。

HttpSession和HttpRequest参照前面文章介绍。
ServletContextListener接口
-void contextInitialized(ServletContextEvent sce)
-void contextDestroyed(ServletContextEvent sce)
web应用加载被创建,卸载被销毁。
HttpSessionListener接口
-void sessionCreated(HttpSessionEvent se) 
-void sessionDestroyed(HttpSessionEvent se)
可以用来模糊统计在线人数,创建session+1,销毁后-1
第一次访问一个JSP或者Servlet时,且JSP或Servlet中允许,并且尚没创建session时,
服务器会创建Session.
调用session.invalidate()方法时,被销毁。
客户端浏览器关闭,不会销毁session
由于session有持久化处理,服务器端重启不一定会销毁Session

如果想让浏览器保留上一次的session,比如保留持续登录的状态,可以将session写入cookie,下次自动读出。
Cookie cookie = new Cookie("JSESSIONID", pageContext.getSession().getId());
cookie.setMaxAge(6000);
response.addCookie(cookie);
注意:由于session的Attribute是保存在服务器端的。
同一个sessionID就可以访问上次的Attribute内容。
ServletRequestListener接口
-void requestDestroyed(ServletRequestEvent sre) 
-void requestInitialized(ServletRequestEvent sre) 
发送请求时被创建,一个请求返回时,立即被销毁。
foward转发时,共用一个request。
sendRedirect是不同的request。
若让Listener有效,在wem.xml中配置即可。
实现Listener很简单,只需要实现上述对应的接口,注意由于是接口,当然可以用一个类,将三个接口全部实现。
<listener>
<listener-class>xxxListener</listener-class>
</listener>

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

ServletContextAttributeListener
HttpSessionAttributeListener
ServletRequestAttributeListener
他们可以监听的内容是一样的:
void attributeAdded( event) 
void attributeRemoved( event) 
void attributeReplaced( event) 

3.监听绑定到HttpSession域中的某个对象的状态的事件监听器。

HttpSessionBindingListener
该Listenser不需要再web.xml中绑定即可自动跟踪监听。
需要对应的javaBean实现下面接口即可,当JavaBean被session绑定,或者解除时
会触发相应的监听器。
HttpSessionActivationListener
该Listener涉及到JavaBean的持久化处理(内存写到硬盘,从硬盘读到内存)
※注意如果要使用磁盘读写操作,则需要实现Serializable接口
实现了HttpSessionBindingListener的JavaBean对象,如果同时实现该接口
则可以感知自己被活化(从硬盘中读出,比如服务器启动时)和钝化(写到硬盘,比如服务器关闭)的事件。
活化后触发:void sessionDidActivate(HttpSessionEvent se) 
即将钝化触发:void sessionWillPassivate(HttpSessionEvent se)
 <完>

### MQListener 实现与配置指南 MQListener 是一种用于监听消息队列的机制,通常在基于消息队列的应用程序中使用。以下是对 MQListener 的实现和配置的详细说明。 #### 1. **MQListener 的基本概念** MQListener 是一个接口或类,用于监听消息队列中的消息并对其进行处理。它通常结合消息中间件(如 RabbitMQ、ActiveMQ 或 IBM MQ)使用。当消息到达队列时,MQListener 会自动触发回调方法来处理这些消息[^1]。 #### 2. **Spring AMQP 中的 MQListener 配置** 在 Spring 框架中,可以通过 `@RabbitListener` 注解实现 MQListener 功能。以下是配置步骤: - **添加依赖** 在父工程中添加 AMQP 依赖,确保项目支持 RabbitMQ 消息队列功能。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 这一步确保了项目可以使用 RabbitMQ 的相关功能[^3]。 - **定义监听器** 使用 `@RabbitListener` 注解标记需要监听的消息队列。 ```java import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; @Component public class MessageListener { @RabbitListener(queues = "myQueue") public void listen(String message) { System.out.println("Received Message: " + message); } } ``` #### 3. **ActiveMQ 中的 MQListener 配置** 在 ActiveMQ 中,可以通过实现 `MessageListener` 接口来监听消息队列。 - **实现 MessageListener 接口** 创建一个类实现 `javax.jms.MessageListener` 接口,并重写 `onMessage` 方法。 ```java import javax.jms.JMSException; import javax.jms.Message; import javax.jms.MessageListener; import javax.jms.TextMessage; public class MyMessageListener implements MessageListener { @Override public void onMessage(Message message) { if (message instanceof TextMessage) { try { String text = ((TextMessage) message).getText(); System.out.println("Received Message: " + text); } catch (JMSException e) { e.printStackTrace(); } } } } ``` - **注册监听器** 将监听器注册到队列中。 ```java import javax.jms.Connection; import javax.jms.ConnectionFactory; import javax.jms.Destination; import javax.jms.Session; import org.apache.activemq.ActiveMQConnectionFactory; public class ActiveMQListenerExample { public static void main(String[] args) throws Exception { ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61616"); Connection connection = connectionFactory.createConnection(); connection.start(); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); Destination destination = session.createQueue("TEST QUEUE"); MyMessageListener listener = new MyMessageListener(); session.createConsumer(destination).setMessageListener(listener); // 等待消息 Thread.sleep(10000); session.close(); connection.close(); } } ``` #### 4. **IBM MQ 中的 MQListener 配置** 在 IBM MQ 中,可以通过 `MQQueueManager` 和 `MQGET` 方法实现监听功能。 - **创建通道和队列管理器** 定义通道和队列管理器以连接到远程 MQ 服务器。 ```java import com.ibm.mq.MQEnvironment; import com.ibm.mq.MQGetMessageOptions; import com.ibm.mq.MQMessage; import com.ibm.mq.MQQueue; import com.ibm.mq.MQQueueManager; public class IBMQueueListener { public static void main(String[] args) throws Exception { MQEnvironment.hostname = "10.4.2.241"; MQEnvironment.port = 1414; MQEnvironment.channel = "CLNT_CHAN_PUMA"; MQQueueManager qMgr = new MQQueueManager("QMGR_NAME"); MQQueue queue = qMgr.accessQueue("QUEUE_NAME", MQC.MQOO_INPUT_AS_Q_DEF); while (true) { MQMessage message = new MQMessage(); MQGetMessageOptions gmo = new MQGetMessageOptions(); queue.get(message, gmo); System.out.println("Received Message: " + message.readUTF()); } } } ``` ####
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值