<?php
// 我的 session 啟動函式,支援時間戳記管理
function my_session_start() {
session_start();
// 不允許使用太舊的 session ID
if (!empty($_SESSION['deleted_time']) && $_SESSION['deleted_time'] < time() - 180) {
session_destroy();
session_start();
}
}
// 我的 session ID 重生函式
function my_session_regenerate_id() {
// session 啟用時呼叫 session_create_id() 以
// 確保不會發生碰撞。
if (session_status() != PHP_SESSION_ACTIVE) {
session_start();
}
// 警告:切勿使用機密字串作為前綴!
$newid = session_create_id('myprefix-');
// 設定刪除時間戳記。基於某些原因,session 資料不能立即刪除。
$_SESSION['deleted_time'] = time();
// 結束 session
session_commit();
// 確保接受使用者自訂的 session ID
// 注意:您必須啟用 use_strict_mode 才能正常運作。
ini_set('session.use_strict_mode', 0);
// 設定新的自訂 session ID
session_id($newid);
// 使用自訂 session ID 啟動
session_start();
}
// 確保 use_strict_mode 已啟用。
// 基於安全考量,use_strict_mode 為必要設定。
ini_set('session.use_strict_mode', 1);
my_session_start();
// Session ID 必須在以下情況下重新產生:
// - 使用者登入時
// - 使用者登出時
// - 經過一定時間後
my_session_regenerate_id();
// 撰寫您的程式碼
?>