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中文網的支持!