什么是监听器?

news/2024/11/24 9:45:06/

前言:重新回忆一下,过滤器,拦截器,监听器! 这三者在实际开发中所起到的作用非同小可.实际开发中必须会的知识点.

千里之行,积于跬步

此图是帮助我们更好整理.

WEB监听器

1,什么是监听器?

web监听器是一种Servlet中的特殊的类,它能帮助开发者监听web中特定的对象,例如ServletContext,HttpSession,ServletRequest三者的创建与销毁跟修改.它能再某些动作的前后增加处理,实现监控

2 监听器通常的用途

*监听器利用HttpServletLisener 统计在线人数

*加载初始化信息:利用ServletContextListener

*统计网站的访问量

*实现访问监控

3 监听器的创建

  首先需要创建一个监听器,实现某种接口,例如我想实现一个对在线人数的监控,可以创建如下的监听器:

public class MyListener implements HttpSessionListener{private int userNumber = 0;public void sessionCreated(HttpSessionEvent arg0) {userNumber++;arg0.getSession().setAttribute("userNumber", userNumber);}public void sessionDestroyed(HttpSessionEvent arg0) {userNumber--;arg0.getSession().setAttribute("userNumber", userNumber);}
}

然后在web.xml中配置该监听器,在web-app中添加:

  <listener><listener-class>com.test.MyListener</listener-class></listener>

在JSP中添加访问人数:

<body>在线人数:<%=session.getAttribute("userNumber") %><br/>
</body>

当我使用我的浏览器访问时,执行结果如下:

 

当打开另一个浏览器访问时:

1,监听器的分类

按照监听对象的划分,可以分为三种:

ServletContext监控:对应监控application内置对象的创建跟销毁.

当web容器开启时,执行contextInitialized方法;

当容器关闭或者重启时,执行contextDestroyed方法.

实现方式:直接实现ServletContextListener接口:

public class MyServletContextListener implements ServletContextListener{public void contextDestroyed(ServletContextEvent sce) {}public void contextInitialized(ServletContextEvent sce) {}
}

HttpSession监控:对应监控session内置对象的创建和销毁。

  当打开一个新的页面时,开启一个session会话,执行sessionCreated方法;当页面关闭session过期时,或者容器关闭销毁时,执行sessionDestroyed方法。

  实现方式:直接实现HttpSessionListener接口:

public class MyHttpSessionListener implements HttpSessionListener{public void sessionCreated(HttpSessionEvent arg0) {}public void sessionDestroyed(HttpSessionEvent arg0) {}
}

ServletRequest监控:对应监控request内置对象的创建和销毁。

  当访问某个页面时,出发一个request请求,执行requestInitialized方法;当页面关闭时,执行requestDestroyed方法。

  实现方式,直接实现ServletRequestListener接口:

public class MyServletRequestListener implements ServletRequestListener{public void requestDestroyed(ServletRequestEvent arg0) {}public void requestInitialized(ServletRequestEvent arg0) {}
}

2 按照监听事件划分:

  2.1 监听事件自身的创建和销毁:同上面的按对象划分。

  2.2 监听属性的新增、删除和修改.

  监听属性的新增、删除和修改也是划分成三种,分别针对于ServletContext、HttpSession、ServletRequest对象.

  ServletContext,实现ServletContextAttributeListener接口:

  通过调用ServletContextAttribtueEvent的getName方法可以得到属性的名称。

public class MyServletContextAttrListener implements ServletContextAttributeListener{public void attributeAdded(ServletContextAttributeEvent hsbe) {System.out.println("In servletContext added :name = "+hsbe.getName());}public void attributeRemoved(ServletContextAttributeEvent hsbe) {System.out.println("In servletContext removed :name = "+hsbe.getName());}public void attributeReplaced(ServletContextAttributeEvent hsbe) {System.out.println("In servletContext replaced :name = "+hsbe.getName());}}

HttpSession,实现HttpSessionAttributeListener接口:

public class MyHttpSessionAttrListener implements HttpSessionAttributeListener{public void attributeAdded(HttpSessionBindingEvent hsbe) {System.out.println("In httpsession added:name = "+hsbe.getName());}public void attributeRemoved(HttpSessionBindingEvent hsbe) {System.out.println("In httpsession removed:name = "+hsbe.getName());}public void attributeReplaced(HttpSessionBindingEvent hsbe) {System.out.println("In httpsession replaced:name = "+hsbe.getName());}}

ServletRequest,实现ServletRequestAttributeListener接口:

public class MyServletRequestAttrListener implements ServletRequestAttributeListener{public void attributeAdded(ServletRequestAttributeEvent hsbe) {System.out.println("In servletrequest added :name = "+hsbe.getName());}public void attributeRemoved(ServletRequestAttributeEvent hsbe) {System.out.println("In servletrequest removed :name = "+hsbe.getName());}public void attributeReplaced(ServletRequestAttributeEvent hsbe) {System.out.println("In servletrequest replaced :name = "+hsbe.getName());}}

2.3 监听对象的状态:

  针对某些POJO类,可以通过实现HttpSessionBindingListener接口,监听POJO类对象的事件。例如:

public class User implements HttpSessionBindingListener,Serializable{private String username;private String password;public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public void valueBound(HttpSessionBindingEvent hsbe) {System.out.println("valueBound name: "+hsbe.getName());}public void valueUnbound(HttpSessionBindingEvent hsbe) {System.out.println("valueUnbound name: "+hsbe.getName());}}

Session数据的钝化与活化:

  由于session中保存大量访问网站相关的重要信息,因此过多的session数据就会服务器性能的下降,占用过多的内存。因此类似数据库对象的持久化,web容器也会把不常使用的session数据持久化到本地文件或者数据中。这些都是有web容器自己完成,不需要用户设定。

  不用的session数据序列化到本地文件中的过程,就是钝化;

  当再次访问需要到该session的内容时,就会读取本地文件,再次放入内存中,这个过程就是活化。

  类似的,只要实现HttpSeesionActivationListener接口就是实现钝化与活化事件的监听:

public class User implements HttpSessionBindingListener,
HttpSessionActivationListener,Serializable{private String username;private String password;public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}public void valueBound(HttpSessionBindingEvent hsbe) {System.out.println("valueBound name: "+hsbe.getName());}public void valueUnbound(HttpSessionBindingEvent hsbe) {System.out.println("valueUnbound name: "+hsbe.getName());}public void sessionDidActivate(HttpSessionEvent hsbe) {System.out.println("sessionDidActivate name: "+hsbe.getSource());}public void sessionWillPassivate(HttpSessionEvent hsbe) {System.out.println("sessionWillPassivate name: "+hsbe.getSource());}}

getAttribute与getParameter的区别

  这部分是对JSP的扩展,经常在JSP或者Servlet中获取数据,那么getAttribute与getParameter有什么区别呢?

  1 从获取到数据的来源来说:

  getAttribtue获取到的是web容器中的值,比如:

  我们在Servlet中通过setAttribute设定某个值,这个值存在于容器中,就可以通过getAttribute方法获取;

 

  getParameter获取到的是通过http传来的值,比如这样一个http请求:

http:localhost:8080/test/test.html?username=xingoo

  还有其他的GET和POST方式,都可以通过getParameter来获取。

  2 从获取到的数据类型来说:

  getAttribute返回的是一个对象,Object。

  getParameter返回的是,前面页面中某个表单或者http后面参数传递的值,是个字符串。


http://www.ppmy.cn/news/345057.html

相关文章

watch监听

1.概念 1、在vue中watch用来监听数据的变化&#xff0c;当数据变化时可以执行一些操作 2、第一次绑定watch时&#xff0c;不会执行监听函数&#xff0c;发生改变时才会触发监听。 3、如果想要第一次绑定watch时触发监听&#xff0c;则使用handler方法&#xff1a;如果immed…

监听器

在Android中&#xff0c;我们可以通过事件处理使UI与用户互动(UI Events)。 UI的用户事件处理&#xff0c;即View处理用户的操作&#xff0c;在应用程序中几乎不可避免。View是重要的类&#xff0c;它是与用户互动的前线&#xff1b;在Android框架的设计中&#xff0c;以事件监…

监听监听~

java 监听 抛砖引玉 &#xff0c;汲取百家之长~ - java的监听 分2种吧 自己总结 1.界面化编程使用&#xff08;一般C/s架构&#xff09; 2.网页web编程使用&#xff08;一般B/s架构&#xff09; 首先&#xff0c; 进行过Java图形界面编程的同学会发现&#xff0c;各种控…

151-B-DC24V、252-B-AC220V气压控制方向阀

151-B-DC24V、252-B-AC220V、332-B-DC24V、453-B-AC220V、232-B-AC110V、351-B-DC24V、431-B-DC12V、253-B-DC24V气动电磁阀体积小,流量大,外形美观,性能可靠.使用寿命长.适用于机电一体化领域.有多重规格和产品颜色可选择&#xff0c;规格G1/8、G1/4、G3/8、G1/2、电控方式&am…

物理服务器有哪些优势?

目前大型企业在选择公司服务器的时候往往会选择物理服务器&#xff0c;因为物理服务器租用费用相对较高&#xff0c;中小型企业使用不划算&#xff0c;而且也会造成资源浪费&#xff0c;但是最近我们接收到从其他服务器商那里转来的客户中&#xff0c;我们发现一些问题&#xf…

是否要捕获 Throwable

Throwable 是什么 Throwable 是 error 和 exception 的基类&#xff0c;关系如下&#xff1a; #mermaid-svg-hAzUVSdnEcAnECPY {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-hAzUVSdnEcAnECPY .error-icon{fill:#…

怎么解决联想笔记本电脑待机后黑屏无法唤醒

闲着没事儿&#xff0c;打开了联想的键盘管理器 于是乎&#xff0c;就按下了Fn4,就是使电脑待机&#xff0c;但问题是&#xff0c;无论我按什么键&#xff0c;电脑都是黑屏&#xff0c;所以就强制关机&#xff0c;然后再开机&#xff0c;最后在网上找到了解决方法。 首先&#…

104.二叉树的最大深度

2023.6.12 层序遍历记录层数即可 class Solution:def maxDepth(self, root: TreeNode) -> int:if not root:return 0depth 0queue collections.deque([root])while queue:depth 1for _ in range(len(queue)):node queue.popleft()if node.left:queue.append(node.left)…