溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JSP中如何實(shí)現(xiàn)基于Session的在線用戶統(tǒng)計(jì)分析

發(fā)布時(shí)間:2021-11-22 09:52:59 來源:億速云 閱讀:153 作者:小新 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)JSP中如何實(shí)現(xiàn)基于Session的在線用戶統(tǒng)計(jì)分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

JSP作為后起之秀能夠在服務(wù)器編程環(huán)境中占據(jù)一定地位,是和它良好支持一系列業(yè)界標(biāo)準(zhǔn)密切相關(guān)的。Session就是它提供的基礎(chǔ)設(shè)施之一。作為一個(gè)程序員,你可以不介意具體在客戶端是如何實(shí)現(xiàn),就方便的實(shí)現(xiàn)簡單的基于session的用戶管理?,F(xiàn)在對于處理在線用戶,有幾種不同的處理方法。

一種是頁面刷新由用戶控制,服務(wù)器端控制一個(gè)超時(shí)時(shí)間比如30分鐘,到了時(shí)間之后用戶沒有動(dòng)作就被踢出。這種方法的優(yōu)點(diǎn)是,如果用戶忘了退出,可以防止別人惡意操作。缺點(diǎn)是,如果你在做一件很耗時(shí)間的事情,超過了這個(gè)時(shí)間限制,submit的時(shí)候可能要再次面臨登陸。如果原來的葉面又是強(qiáng)制失效的話,就有可能丟失你做的工作。在實(shí)現(xiàn)的角度來看,這是最簡單的,Server端默認(rèn)實(shí)現(xiàn)的就是這樣的模式。

另一種方式是,站點(diǎn)采用框架結(jié)構(gòu),有一個(gè)Frame或者隱藏的iframe在不斷刷新,這樣你永遠(yuǎn)不會(huì)被踢出,但是服務(wù)器端為了判斷你是否在線,需要定一個(gè)發(fā)呆時(shí)間,如果超過這個(gè)發(fā)呆時(shí)間你除了這個(gè)自動(dòng)刷新的葉面外沒有刷新其他葉面的話,就認(rèn)為你已經(jīng)不在線了。采取這種方式的典型是 xici.net。 他的優(yōu)點(diǎn)是可以可以利用不斷的刷新實(shí)現(xiàn)一些類似server-push的功能,比如網(wǎng)友之間發(fā)送消息。

不管哪一種模式,為了實(shí)現(xiàn)瀏覽當(dāng)前所有的在線用戶,還需要做一些額外的工作。servlet API中沒有得到Session列表的API。

可以利用的是Listener. Servlet 2.2和2.3規(guī)范在這里略微有一些不一樣。2.2中HttpSessionBindingListener可以實(shí)現(xiàn)當(dāng)一個(gè)HTTPSession中的 Attribute變化的時(shí)候通知你的類。而2.3中還引入了HttpSessionAttributeListener.鑒于我使用的環(huán)境是 Visual age for java 4和JRun server 3.1,他們還不直接支持Servlet 2.3的編程,這里我用的是HttpSessionBindingListener。

需要做的事情包括做一個(gè)新的類來實(shí)現(xiàn)HttpSessionBindingListener接口。這個(gè)接口有兩個(gè)方法:

public void valueBound(HttpSessionBindingEvent event)  public void valueUnbound(HttpSessionBindingEvent event)

當(dāng)你執(zhí)行Session.addAttribute(String,Object)的時(shí)候,如果你已經(jīng)把一個(gè)實(shí)現(xiàn)了HttpSessionBindingListener接口的類加入為Attribute,Session會(huì)通知你的類,調(diào)用你的 valueBound方法。相反,Session.removeAttribute方法對應(yīng)的是valueUndound方法。

  1. public class HttpSessionBinding implements javax.servlet.
    http.HttpSessionBindingListener     

  2. {     

  3. ServletContext application = null;      

  4. public HttpSessionBinding(ServletContext application)     

  5. {    

  6. super();    

  7. if (application ==null)     

  8. throw new IllegalArgumentException("Null application is not accept.");    

  9. this.application = application;     

  10. }      

  11. public void valueBound(javax.servlet.http.HttpSessionBindingEvent e)    

  12. {     

  13. Vector activeSessions = (Vector) application.getAttribute
    ("activeSessions");    

  14. if (activeSessions == null)    

  15. {     

  16. activeSessions = new Vector();    

  17. }     

  18. JDBCUser sessionUser = (JDBCUser)e.getSession().getAttribute("user");   

  19. if (sessionUser != null)    

  20. {     

  21. activeSessions.add(e.getSession());    

  22. }    

  23. application.setAttribute("activeSessions",activeSessions);     

  24. }      

  25. public void valueUnbound(javax.servlet.http.HttpSessionBindingEvent e)      

  26. {    

  27. JDBCUser sessionUser = (JDBCUser)e.getSession().getAttribute("user");   

  28. if (sessionUser == null)    

  29. {     

  30. Vector activeSessions = (Vector) application.getAttribute
    ("activeSessions");     

  31. if (activeSessions != null)     

  32. {    

  33. activeSessions.remove(e.getSession().getId());    

  34. application.setAttribute("activeSessions",activeSessions);     

  35. }    

  36. }     

  37. }    

  38. }  


假設(shè)其中的JDBCUser類是一個(gè)任意User類。在執(zhí)行用戶登錄時(shí),把User類和HttpSessionBinding類都加入到Session中去。

這樣,每次用戶登錄后,在application中的attribute "activeSessions"這個(gè)vector中都會(huì)增加一條記錄。每當(dāng)session超時(shí),valueUnbound被觸發(fā),在這個(gè)vector中刪去將要被超時(shí)的session。

  1. public void login()    

  2. throws ACLException,SQLException,IOException    

  3. {     

  4. /* get JDBC User Class */     

  5. if (user != null)     

  6. {    

  7. logout();     

  8. }     

  9. {    

  10. // if session time out, or user didn't login, 
    save the target url temporary.     

  11. JDBCUserFactory uf = new JDBCUserFactory();     

  12. if ( (this.request.getParameter("userID")==null)     

  13. || (this.request.getParameter("password")==null) )    

  14. {     

  15. throw new ACLException("Please input a valid 
    userName andpassword."); }     

  16. JDBCUser user = (JDBCUser) uf.UserLogin(   

  17. this.request.getParameter("userID"),   

  18. this.request.getParameter("password") );     

  19. user.touchLoginTime();     

  20. this.session.setAttribute("user",user);   

  21. this.session.setAttribute("BindingNotify",new 
    HttpSessionBinding(application));    

  22. }     

  23. }  

Login的時(shí)候,把User和這個(gè)BindingNotofy目的的類都加入到session中去。logout的時(shí)候,就要主動(dòng)在activeSessions這個(gè)vector中刪去這個(gè)session。

  1. public void logout()    

  2. throws SQLException,ACLException    

  3. {     

  4. if (this.user == null && this.session.getAttribute("user")==null)     

  5. {    

  6. return;     

  7. }      

  8. Vector activeSessions = (Vector)this.application.
    getAttribute("activeSessions");     

  9. if (activeSessions != null)     

  10. {  

  11. activeSessions.remove(this.session);  

  12. application.setAttribute("activeSessions",activeSessions);     

  13. }      

  14. java.util.Enumeration e = this.session.getAttributeNames();      

  15. while (e.hasMoreElements())     

  16. {    

  17. String s = (String)e.nextElement();  

  18. this.session.removeAttribute(s);     

  19. }     

  20. this.user.touchLogoutTime();     

  21. this.user = null;    

  22. }  

關(guān)于“JSP中如何實(shí)現(xiàn)基于Session的在線用戶統(tǒng)計(jì)分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI