首頁 >Java >java教程 >JavaWeb Session失效時間設定方法

JavaWeb Session失效時間設定方法

高洛峰
高洛峰原創
2017-01-21 16:29:151810瀏覽

 session失效時間設定方法,具體方法如下:

一、java程式碼  

request.getSession().setMaxInactiveInterval(1800);/*秒为单位,1800= 60*30 即30分种*/

二、web.xml 

<session-config>  <!--分钟为单位-->
  <session-timeout>30</session-timeout>
</session-config>

三、web伺服器resin.conf,tomcat,

<session-config>  <!--分钟为单位-->
  <session-timeout>30</session-timeout>
  <enable-url-rewriting>false</enable-url-rewriting>
</session-config>

優先: 1 > 3 > 2

session 在tomcat重啟後一般也不會失效,關閉瀏覽器後,session失效

在一般系統中,也可能需要在session失效後做一些操作: 

(1)控制用戶數,當session失效後,系統的用戶數減少一個等,控制用戶數在一定範圍內,確保系統的效能。 

(2)控制一個使用者多次登錄,當session有效時,如果相同使用者登錄,就提示已經登入了,當session失效後,就可以不用提示,直接登入了。

那麼如何在session失效後,進行一連串的操作呢? 

這裡就需要用到監聽器了,也就是當session因為各種原因失效後,監聽器就可以監聽到,然後執行監聽器中定義好的程序就可以了。

監聽器類別為: HttpSessionListener 類,有 sessionCreated 和sessionDestroyed 兩個方法

  自己可以繼承這個類,然後分別實現。

  sessionCreated指在session創建時執行的方法

  sessionDestroyed指在session失效時執行的方法

如下:

public class OnlineListener implements HttpSessionListener{  
   public void sessionCreated(HttpSessionEvent event) {  
      HttpSession ses = event.getSession();  
      String id=ses.getId()+ses.getCreationTime();  
      SummerConstant.UserMap.put(id, Boolean.TRUE);   //添加用户  
    }  
    public void sessionDestroyed(HttpSessionEvent event) {  
      HttpSession ses = event.getSession();  
      String id=ses.getId()+ses.getCreationTime();  
      synchronized (this) {  
        SummerConstant.USERNUM--;      //用户数减一  
        SummerConstant.UserMap.remove(id); //从用户组中移除掉,用户组为一个map  
     }  
    }  
 }

 

上面是一個簡單的利用session監聽用戶數的方法,在實際過程中,可能比這個複雜得多。 

例如要同時實作 ServletContextListener,HttpSessionListener兩個接口,重寫它們的方法等。

以上所述是小編給大家介紹的JavaWeb Session失效時間設定方法,希望對大家有幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對PHP中文網的支持!

更多JavaWeb Session失效時間設定方法相關文章請關注PHP中文網!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn