java监听器详解_史上最全面‘java监听器’解读,读完就能用进项目

Web监听器导图详解

监听器是JAVA Web开发中很重要的内容,其中涉及到的知识,能够参考下面导图:html

da0144c09cdffac4f0721004906d3355.png

1、Web监听器

1. 什么是web监听器?

web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,好比ServletContext,HttpSession,ServletRequest的建立和销毁;变量的建立、销毁和修改等。能够在某些动做先后增长处理,实现监控。java

2. 监听器经常使用的用途

一般使用Web监听器作如下的内容:程序员

统计在线人数,利用HttpSessionLisenerweb

加载初始化信息:利用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中添加:tomcat

com.test.MyListener

在JSP中添加访问人数:服务器

在线人数:

当我使用个人浏览器访问时,执行结果以下:

13739160fa39af79f9d07f7d67d20f75.png

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

97fa8d9887468992f39f3eff86330b7a.png

因为打开另外一个浏览器访问,至关于另外一个会话,所以在线人数会增长。

对于3.0版本的Servlet来讲,还支持使用注解的方式进行配置。

那么接下来看看都有哪些监听器以及方法吧!

2、监听器的分类

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());

}

}

3、Servlet版本与Tomcat版本

首先看一下Tomcat官网给出的匹配:

912a563bc21e7fa2202c42807d3ee284.png

若是版本不匹配,那么tomcat是不能发布该工程的,首先看一下版本不匹配时,会发生什么!

我试图建立一个web工程,而且选取了Servlet3.0版本:

fa00b31755ea5ca28edea091ec23fcd4.png

而后我想要在tomcat6中发布,能够看到报错了!

JDK版本不对....这是在平时开发若是对Servlet不熟悉的web新手,常犯的错误。

678775174506df5b4e2ad760e3f8d1ab.png

解决方法:

1 在建立时,直接发布到Tomcat容器中,此时Servlet仅仅会列出Tomcat支持的版本:

989cea48da4f2751227a7ec6c0ca2fef.png

2 修改工程Servlet版本配置信息,文件为:工做目录\SessionExample.settings\org.eclipse.wst.common.project.facet.core.xml

5818cdb591ef47b692302d70.html

5818cdb591ef47b692302d70.html

4、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后面参数传递的值,是个字符串。

原文:https://juejin.cn/post/6911973816218435597

推荐阅读

00231

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值