Php中設定Session超時時間登入時間限制
阿新 • • 發佈:2019-01-31
最近某個PHP專案用到了限制登入時間的功能,比如使用者登入系統60分鐘(www.phpfensi.com)後如果沒有操作就自動退出,我搜索了網路收集了有以下方法可供參考.
第一種方法即設定php.ini配置檔案,設定session.gc_maxlifetime和session.cookie_lifetime節點屬性值,當然也可以使用ini_set函式改變當前上下文環境的屬性值,程式碼如下:
ini_set('session.gc_maxlifetime', "3600"); // 秒
ini_set("session.cookie_lifetime","3600"); // 秒
第二種方法即設定Session時間戳,比如下面的辦法,在登入成功時設定時間戳為當前時間推後1小時,$_SESSION['expiretime'] = time() + 3600;,在檢查使用者登入情況使用如下程式碼:
if(www.phpfensi.com)(isset($_SESSION['expiretime'])) {
if($_SESSION['expiretime'] < time()) {
unset($_SESSION['expiretime']);
header('Location: logout.php?TIMEOUT'); // 登出
exit(0);
} else {
$_SESSION['expiretime'] = time() + 3600; // 重新整理時間戳
}
}
經驗,其實session超時時間php預設就有一會時間了,當然我們可以按上面的方法來設定一下了,這種做法我覺得使用cookies會更方便.