更新時間:2021-08-04 16:48:02 來源:動力節點 瀏覽982次
具體設置很簡單,方法有三種:
1.在主頁面或者公共頁面中加入:session.setMaxInactiveInterval(900);
參數900單位是秒,即在沒有活動15分鐘后,session將失效。設置為-1將永不關閉。
這里要注意這個session設置的時間是根據服務器來計算的,而不是客戶端。所以如果是在調試程序,應該是修改服務器端時間來測試,而不是客戶端。
2.也是比較通用的設置session失效時間的方法,就是在項目的web.xml中設置
<lt;session-config>
<lt;session-timeout>15</session-timeout>
<lt;/session-config>
這里的15也就是15分鐘失效.
3.直接在應用服務器中設置,如果是tomcat,可以在tomcat目錄下conf/web.xml中
找到<session-config>元素,tomcat默認設置是30分鐘,只要修改這個值就可以了,負數或0為不限制session失效時間。
如圖:
需要注意的是如果上述三個地方如果都設置了,有個優先級的問題,從高到低:
(1)>(2)>(3)
session的過期時間計算是從當前session的最后一次請求開始的。
下面是測試代碼:
第一步:配置web.xml(設置失效時間,和監聽路徑)
1.失效時間單位是分鐘,即1分鐘后失效
<session-config>
<session-timeout>1</session-timeout>
</session-config>
2.設置監聽路徑 (監聽類所在的全路徑)
<listener>
<listener-class>
com.controller.SessionListener
</listener-class>
</listener>
3.新建監聽類,代碼如下
package com.controller;
import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import org.springframework.stereotype.Controller;
public class SessionListener implements HttpSessionListener{
public void sessionCreated(HttpSessionEvent event) {
HttpSession ses = event.getSession();
String id=ses.getId()+ses.getCreationTime();
System.out.println("1111111111111"); //創建會話時輸出
}
public void sessionDestroyed(HttpSessionEvent event) {
HttpSession ses = event.getSession();
String id=ses.getId()+ses.getCreationTime();
synchronized (this) {
System.out.println("2222222222222");//失效時輸出
}
}
}
以上就是動力節點小編介紹的"Session過期時間設置",希望對大家有幫助,想了解更多可查看Session執行原理。動力節點在線學習教程,針對沒有任何Java基礎的讀者學習,讓你從入門到精通,主要介紹了一些Java基礎的核心知識,讓同學們更好更方便的學習和了解Java編程,感興趣的同學可以關注一下。
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習