这几天在做一个在线人数统计的程序,我费了好大劲在网上查了一些资料,经过调试学到了一些东西,在这写两个简单的程序介绍一下:
1.新建一个工程OnlineCount,包结构如下图所示:
javaWeb 在线人数统计_新建
demo1:新建一个OnlineCounter.java
代码如下:
 
javaWeb 在线人数统计_统计_02package com.dr.demo2.servlet; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpServlet;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpServletRequest;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpSessionEvent;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpSessionListener; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
import org.apache.log4j.Logger; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
public class OnlineCounter extends HttpServlet implements HttpSessionListener 
javaWeb 在线人数统计_休闲_12    
{
javaWeb 在线人数统计_新建_15    
private static Logger log = Logger.getLogger(OnlineCounter.class);
javaWeb 在线人数统计_新建_15    
private static final long serialVersionUID = 1L;  
javaWeb 在线人数统计_新建_15    
private static int sessionCounter = 0;  
javaWeb 在线人数统计_休闲_18    
public OnlineCounter(){  
javaWeb 在线人数统计_新建_15        log.info(
"OnlineCounter initialized.");  
javaWeb 在线人数统计_在线人数_22    }
  
javaWeb 在线人数统计_新建_23    
public void sessionCreated(HttpSessionEvent se) {
javaWeb 在线人数统计_新建_15        sessionCounter
++;  
javaWeb 在线人数统计_新建_15        log.info(
"session created:" + sessionCounter);  
javaWeb 在线人数统计_在线人数_22    }
  
javaWeb 在线人数统计_统计_29    
public void sessionDestroyed(HttpSessionEvent se) 
javaWeb 在线人数统计_新建_15        sessionCounter
--;  
javaWeb 在线人数统计_新建_15        log.info(
"session destroied");  
javaWeb 在线人数统计_在线人数_22    }
  
javaWeb 在线人数统计_在线人数_35    
public static int getOnlineSession() {  
javaWeb 在线人数统计_新建_15        
return sessionCounter;  
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_新建_41}
 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
在web.xml中写入以下语句:
   
javaWeb 在线人数统计_统计_02 <listener>   
javaWeb 在线人数统计_统计_02    
<listener-class>   
javaWeb 在线人数统计_统计_02    com.dr.demo2.servlet.OnlineCounter   
javaWeb 在线人数统计_统计_02    
</listener-class>   
javaWeb 在线人数统计_统计_02    
</listener>  
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02    
<session-config>
javaWeb 在线人数统计_统计_02    
<session-timeout>1</session-timeout><!-- 默认时间为分钟 -->
javaWeb 在线人数统计_统计_02    
</session-config> 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
新建一个online.jsp,在body中写入以下语句:
<%@   page   import= "com.dr.demo2.servlet.OnlineCounter"   %>  
    在线: <%=  OnlineCounter.getOnlineSession()   %>人 
这样就可以启动服务器运行。
1.初始启动服务器运行时:控制台上会下面的日志信息:
2011-01-18 11:11:47,968 [main] [com.dr.demo2.servlet.OnlineCounter] [INFO] - OnlineCounter initialized.
2.在浏览器地址栏中中访问online.jsp:控制台上打出,
2011-01-18 11:37:16,031 [http-8080-1] [com.dr.demo2.servlet.OnlineCounter] [INFO] - session created:1
3.大约一分钟过后,控制台上会打出:
2011-01-18 11:39:10,265 [ContainerBackgroundProcessor[StandardEngine[Catalina]]] [com.dr.demo2.servlet.OnlineCounter] [INFO] - session destroied
这跟在web.xml中的时间有关系
在调试时你会发现,当一个电脑上装有不同的浏览器时,用另一个浏览器再次访问时,会打出:
2011-01-18 11:38:16,031 [http-8080-1] [com.dr.demo2.servlet.OnlineCounter] [INFO] - session created:2
为了避免上述失误产生,在程序中加入IP过滤:
demo2:新建一个SessionCounter.java
代码如下:
 
javaWeb 在线人数统计_统计_02package com.dr.demo2.servlet; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
import java.io.IOException;
javaWeb 在线人数统计_统计_02
import java.sql.Timestamp;
javaWeb 在线人数统计_统计_02
import java.util.ArrayList; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
import javax.servlet.ServletException;
javaWeb 在线人数统计_统计_02
import javax.servlet.ServletRequestEvent;
javaWeb 在线人数统计_统计_02
import javax.servlet.ServletRequestListener;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpServletRequest;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpServletResponse;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpSession;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpSessionEvent;
javaWeb 在线人数统计_统计_02
import javax.servlet.http.HttpSessionListener; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
import org.apache.log4j.Logger; 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_新建_72
public class SessionCounter implements HttpSessionListener,ServletRequestListener {
javaWeb 在线人数统计_新建_15    
private static Logger log = Logger.getLogger(SessionCounter.class);
javaWeb 在线人数统计_新建_15    
private static final String CONTENT_TYPE = "text/html; charset=GBK";
javaWeb 在线人数统计_新建_15    
private static int activeSessions = 0;//当前活动的人数
javaWeb 在线人数统计_新建_15
    private HttpServletRequest request;
javaWeb 在线人数统计_新建_15    
private static ArrayList list = new ArrayList();//用来存放不同ip的地址 
javaWeb 在线人数统计_新建_15

javaWeb 在线人数统计_在线人数_81    
public void init() throws ServletException {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter init!"); 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_休闲_88    
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter doGet!");
javaWeb 在线人数统计_新建_15        response.setContentType(CONTENT_TYPE);
javaWeb 在线人数统计_新建_15        HttpSession session 
= request.getSession();
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_休闲_96    
public void destroy() {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter destroy!");
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_新建_102    
public void requestDestroyed(ServletRequestEvent event) {
javaWeb 在线人数统计_新建_15        
//To change body of implemented methods use File | Settings | File Templates.
javaWeb 在线人数统计_新建_15
        log.info("SessionCounter requestDestroyed!");
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_职场_109    
public void requestInitialized(ServletRequestEvent sre){
javaWeb 在线人数统计_新建_15        request
=(HttpServletRequest)sre.getServletRequest();
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter requestInitialized!");
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_在线人数_116    
public void sessionCreated(HttpSessionEvent httpSessionEvent) {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter sessionCreater!");
javaWeb 在线人数统计_新建_15        String sessionId 
= httpSessionEvent.getSession().getId();
javaWeb 在线人数统计_新建_15        Timestamp createTime 
= new Timestamp(System.currentTimeMillis());
javaWeb 在线人数统计_新建_15        String loginIp 
= request.getRemoteAddr();
javaWeb 在线人数统计_新建_15        
boolean rs = true;
javaWeb 在线人数统计_新建_124        
if(list.size() > 0){
javaWeb 在线人数统计_新建_127            
for(int i = 0;i < list.size(); i ++){
javaWeb 在线人数统计_职场_130                
if(loginIp.equals(list.get(i))){
javaWeb 在线人数统计_新建_15                    rs 
= false;
javaWeb 在线人数统计_在线人数_22                }

javaWeb 在线人数统计_在线人数_22            }

javaWeb 在线人数统计_在线人数_22        }

javaWeb 在线人数统计_统计_137        
if(rs){                      //如果队列中存在相同的IP 则SESSION不增加
javaWeb 在线人数统计_新建_15
            list.add(loginIp);
javaWeb 在线人数统计_新建_15           log.info(
"ipList队列新增ip: "+loginIp);
javaWeb 在线人数统计_新建_15            activeSessions
++;
javaWeb 在线人数统计_新建_15            log.info(
"新增SESSION,sessionId = " + sessionId +"; createTime = " + createTime
javaWeb 在线人数统计_新建_15                             
+ "; loginIp = " + loginIp +"; 当前总SESSION值为 "+activeSessions);
javaWeb 在线人数统计_在线人数_22        }

javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_新建_148    
public void sessionDestroyed(HttpSessionEvent httpSessionEvent) {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter sessionDestroyed!");
javaWeb 在线人数统计_新建_15        String sessionId 
= httpSessionEvent.getSession().getId();
javaWeb 在线人数统计_新建_15        Timestamp overTime 
= new Timestamp(System.currentTimeMillis());
javaWeb 在线人数统计_新建_15        String loginIp 
= request.getRemoteAddr();
javaWeb 在线人数统计_在线人数_155        
if(activeSessions>0){
javaWeb 在线人数统计_在线人数_158            
if(list.size() > 0){
javaWeb 在线人数统计_新建_161                
for(int i = 0;i < list.size(); i ++){
javaWeb 在线人数统计_休闲_164                    
if(loginIp.equals(list.get(i))){
javaWeb 在线人数统计_新建_15                        list.remove(i);  
javaWeb 在线人数统计_新建_15                        log.info(
"ipList队列移除ip: "+loginIp);
javaWeb 在线人数统计_在线人数_22                    }

javaWeb 在线人数统计_在线人数_22                }

javaWeb 在线人数统计_在线人数_22            }

javaWeb 在线人数统计_新建_15            activeSessions
--;                   //在用户销毁的时候,从队列中踢出这个IP
javaWeb 在线人数统计_新建_15
            log.info("销毁SESSION,sessionId = " + sessionId +"; overTime = " + overTime
javaWeb 在线人数统计_新建_15                             
+ "; loginIp = " + loginIp +"; 当前总SESSION值为 "+activeSessions);
javaWeb 在线人数统计_在线人数_22        }

javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_新建_178    
public static int getActiveSessions() {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter getActiveSessions!");
javaWeb 在线人数统计_新建_15        
return activeSessions;
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_统计_185    
public void setActiveSessions(int i) {
javaWeb 在线人数统计_新建_15        log.info(
"SessionCounter setActiveSessions!");
javaWeb 在线人数统计_新建_15        activeSessions 
= i;
javaWeb 在线人数统计_在线人数_22    }
 
javaWeb 在线人数统计_新建_15
javaWeb 在线人数统计_新建_41}
 
javaWeb 在线人数统计_统计_02
javaWeb 在线人数统计_统计_02
将xml中的代码改为如下代码:
   
javaWeb 在线人数统计_统计_02 <listener>   
javaWeb 在线人数统计_统计_02    
<listener-class>com.dr.demo2.servlet.SessionCounter</listener-class>   
javaWeb 在线人数统计_统计_02    
</listener>  
javaWeb 在线人数统计_统计_02    
<session-config>
javaWeb 在线人数统计_统计_02    
<session-timeout>1</session-timeout><!-- 默认时间为分钟 -->
javaWeb 在线人数统计_统计_02    
</session-config> 
javaWeb 在线人数统计_统计_02
online.jsp代码改为如下代码:
<%@   page   import= "com.dr.demo2.servlet.SessionCounter"   %>  
    在线: <%=  SessionCounter.getActiveSessions()   %>人 
程序运行结果:
1.访问online.jsp时,控制台输出如下:
javaWeb 在线人数统计_新建_202
2.用不同的浏览器访问时,控制台输出如下:
 javaWeb 在线人数统计_休闲_203
3.用不同的电脑访问时,控制台输出如下:
javaWeb 在线人数统计_统计_204
 
4.大概一分钟过后,控制台上输出如下:
javaWeb 在线人数统计_统计_205
希望各位大虾批评指导!