这篇文章将为大家详细讲解有关利用servlet如何实现一个监听在线人数功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
具体内容如下
ServletContext事件监听器——在针对applicationScope
ServletContextListener (*)
对整个Web应用的装载和卸载进行监听。
, ServletContextAttributeListener
对ServletContext中的信息存放,删除和替换进行监听。
ServletContext就是servlet上下文监听,在Web中表示的是对启动服务和销毁服务进行监听,需要实现的接口:
ServletContextListener接口,实现的就是对上下午进行监听:
空白contextInitialized (ServletContextEvent sce):启动上下文时的监听
空白contextDestroyed (ServletContextEvent sce):销毁上下文时进行的监听
除了对上下文的启动和销毁进行监听的之外,还可以对上下文的属性进行监听:ServletContextAttributeListener接口。
空白attributeAdded (ServletContextAttributeEvent事件):设置上下文属性监听
空白attributeRemoved (ServletContextAttributeEvent事件):移除上下文属性的监听
空白attributeReplaced (ServletContextAttributeEvent事件):修改上下文属性的监听
ServletContextAttributeEvent:事件,可以通过事件取得属性的内容和名称。
·取得属性名称:公共. lang。字符串getName ()
·取得属性的值:公共. lang。对象getValue ()
效果如下图:
当登录一个账号时
打开另一个浏览器,再登录一个账号
如上图,我们可以看的到,程序已经完成了统计在线人数和显示人员列表的功能,那么他的实现流程是什么呢?
我们可以通过ServletContextListener完成在线人数的统计和显示在线人数列表,首先侦听器和过滤器一样要在网络上。xml中进行描述。
代码如下:
& lt; listener> & lt; listener-class> net.jvsun.ListenerTest & lt;/listener>
为了测试这个程序,我们也必须完成用户登录功能。
数据库连接帮助类:
公共类JDBCHelper { 公共静态最终字符串司机=皁racle.jdbc.driver.OracleDriver"; 公共静态最终字符串URL=癹dbc: oracle:薄:@localhost: 1521: xxx"; 公共静态最终字符串DBNAME=皊cott"; 公共静态最终字符串密码=皒xx"; 公共静态连接getConn()抛出异常{ forname(司机); 康涅狄格州=DriverManager连接。getConnection (URL, DBNAME、密码); 返回康涅狄格州; } }
用户实体类:
公共类UserDAO { 公共UserPOJO登录(用户名的字符串,字符串密码){ UserPOJO用户=零; 连接康涅狄格州=零; PreparedStatement pstate=零; ResultSet res=零; 尝试{ 康涅狄格州=JDBCHelper.getConn (); 字符串sql=把≡駃d、用户名的用户信息,用户名=,# 63;和密码=,# 63;“; pstate=conn.prepareStatement (sql); pstate。setString(用户名); pstate。setString(2、密码); res=pstate.executeQuery (); 而(res.next ()) { 用户=new UserPOJO (res.getInt(1),用户名,null); } }捕捉(异常e) { e.printStackTrace (); 最后}{ 尝试{ res.close (); pstate.close (); conn.close (); }捕捉(SQLException e) { e.printStackTrace (); } } 返回用户; } }利用servlet如何实现一个监听在线人数功能