2.10.4 使用ServletRequestListener和ServletRequestAttributeListener

2.10.4 使用ServletRequestListener和ServletRequestAttributeListener

ServletRequestListener

ServletRequestListener用于监听用户请求的到达,实现该接口的监听器需要实现如下两个方法。

  • requestInitialized(ServletRequestEvent sre):用户请求到达、被初始化时触发该方法
  • requestDestroyed(ServletRequestEvent sre):用户请求结束、被销毁时触发该方法

ServletRequestAttributeListener

ServletRequestAttributeListener则用于监听ServletRequest(request)范围内属性的变化,实现该接口的监听器需要实现

  • attributeAdded()
  • attributeRemoved()
  • attributeReplaced()

这三个方法。

由此可见,ServletRequestAttributeListenerServletContextAttributeListener的作用相似,都用于监听属性的改变,
只是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 {
// ------ 实现ServletRequestListener方法 -------------------------------------
// 当用户请求到达、被初始化时触发该方法
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() + "请求被销毁----");
}
// ------ 实现ServletRequestAttributeListener方法 ------------------------------
// 当程序向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();
// 获取被替换的属性名和属性值
String name = event.getName();
Object value = event.getValue();
System.out.println(request + "范围内名为" + name + ",值为" + value + "的属性被替换了!");
}
}

上面的监听器实现类同时实现了ServletRequestListener接口和ServletRequestAttributerListener接口,因此它既可以监听用户请求的初始化和销毁,也可监听request范围内属性的变化。

实现系统日志

由于实现了ServletRequestListener接口的监听器可以非常方便地监听到每次请求的创建、销毁,因此Web应用可通过实现该接口的监听器来监听访问该应用的每个请求,从而实现系统日志。