2.10.4 使用ServletRequestListener和ServletRequestAttributeListener
ServletRequestListener
ServletRequestListener
用于监听用户请求的到达,实现该接口的监听器需要实现如下两个方法。
requestInitialized(ServletRequestEvent sre)
:用户请求到达、被初始化时触发该方法
requestDestroyed(ServletRequestEvent sre)
:用户请求结束、被销毁时触发该方法
ServletRequestAttributeListener
ServletRequestAttributeListener
则用于监听ServletRequest(request)
范围内属性的变化,实现该接口的监听器需要实现
attributeAdded()
、
attributeRemoved()
、
attributeReplaced()
这三个方法。
由此可见,ServletRequestAttributeListener
与ServletContextAttributeListener
的作用相似,都用于监听属性的改变,
只是ServletrequestAttributeListener
监听request
范围内属性的改变,
而ServletContextAttributeListener
监听的是application
范围内属性的改变。
RequestListener.java
需要指出的是,应用程序完全可以采用一个监听器类来监听多种事件,只要让该监听器实现类同时实现多个监听器接口即可,如以下代码所示。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
| package lee;
import javax.servlet.*; import javax.servlet.http.*; import javax.servlet.annotation.*;
@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() + "请求被销毁----"); } public void attributeAdded(ServletRequestAttributeEvent event) { ServletRequest request = event.getServletRequest(); String name = event.getName(); Object value = event.getValue(); System.out.println(request + "范围内添加了名为" + name + ",值为" + value + "的属性!"); }
public void attributeRemoved(ServletRequestAttributeEvent event) { ServletRequest request = event.getServletRequest(); String name = event.getName(); Object value = event.getValue(); System.out.println(request + "范围内名为" + name + ",值为" + value + "的属性被删除了!"); }
public void attributeReplaced(ServletRequestAttributeEvent event) { ServletRequest request = event.getServletRequest(); String name = event.getName(); Object value = event.getValue(); System.out.println(request + "范围内名为" + name + ",值为" + value + "的属性被替换了!"); } }
|
上面的监听器实现类同时实现了ServletRequestListener
接口和ServletRequestAttributerListener
接口,因此它既可以监听用户请求的初始化和销毁,也可监听request
范围内属性的变化。
实现系统日志
由于实现了ServletRequestListener
接口的监听器可以非常方便地监听到每次请求的创建、销毁,因此Web
应用可通过实现该接口的监听器来监听访问该应用的每个请求,从而实现系统日志。