《轻量级Java EE企业应用实战(第3版)--Struts 2+Spring 3+Hibernate整合开发》
2.13.4 使用ServletRequestListener和ServletRequestAttributeListener
ServletRequestListener用于监听用户请求的到达,实现该接口的监听器需要实现如下两个方法。
requestInitialized(ServletRequestEvent sre):用户请求到底、被初始化时触发该方法。
requestDestroyed(ServletRequestEvent sre):用户请求结束、被销毁时触发该方法。
ServletRequestAttributeListener则用于监听ServletRequest(request)范围内属性的变化,实现该接口的监听器需要实现attributeAdded、attributeRemoved、attributeReplaced三个方法。由此可见,ServletRequestAttributeListener与ServletContextAttributeListener的作用相似,都用于监听属性的改变,只是ServletRequestAttributeListener监听request范围内属性的改变,而ServletContextAttributeListener监听的是application范围内属性的改变。
需要指出的是,应用程序完全可以采用一个监听器类来监听多种事件,只要让该监听器实现类同时实现多个监听器接口即可,如以下代码所示。
程序清单:codes\02\2.13\listenerTest\WEB-INF\src\lee\RequestListener.java
- @WebListener
- public class RequestListener
- implements ServletRequestListener ,
ServletRequestAttributeListener - {
- //当用户请求到达、被初始化时触发该方法
- public void requestInitialized(ServletRequestEvent sre)
- {
- HttpServletRequest request =
(HttpServletRequest)sre.getServletRequest(); - System.out.println("----发向" + request.getRequestURI()
- + "请求被初始化----");
- }
- //当用户请求结束、被销毁时触发该方法
- public void requestDestroyed(ServletRequestEvent sre)
- {
- HttpServletRequest request =
(HttpServletRequest)sre.getServletRequest(); - System.out.println("----发向" + request.getRequestURI()
- + "请求被销毁----");
- }
- //当程序向request范围添加属性时触发该方法
- public void attributeAdded(ServletRequestAttributeEvent event)
- {
- ServletRequest request = event.getServletRequest();
- //获取添加的属性名和属性值
- String name = event.getName();
- Object value = event.getValue();
- System.out.println(request + "范围内添加了名为"
- + name + ",值为" + value + "的属性!");
- }
- //当程序从request范围删除属性时触发该方法
- public void attributeRemoved(ServletRequestAttributeEvent event)
- {
- ServletRequest request = event.getServletRequest();
- //获取被删除的属性名和属性值
- String name = event.getName();
- Object value = event.getValue();
- System.out.println(request + "范围内名为"
- + name + ",值为" + value + "的属性被删除了!");
- }
- //当request范围的属性被替换时触发该方法
- public void attributeReplaced(ServletRequestAttributeEvent event)
- {
- ServletRequest request = event.getServletRequest();
- //获取被替换的属性名和属性值
上面的监听器实现类同时实现了ServletRequestListener接口和ServletRequestAttributerListener接口,因此它既可以监听用户请求的初始化和销毁,也可监听request范围内属性的变化。
由于实现了ServletRequestListener接口的监听器可以非常方便地监听到每次请求的创建、销毁,因此Web应用可通过实现该接口的监听器来监听访问该应用的每个请求,从而实现系统日志。