ホームページ >バックエンド開発 >PHPチュートリアル >30 分間非アクティブになった後に PHP セッションを確実に期限切れにする方法は?

30 分間非アクティブになった後に PHP セッションを確実に期限切れにする方法は?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-24 22:56:15435ブラウズ

How to Reliably Expire a PHP Session After 30 Minutes of Inactivity?

30 分後に PHP セッションを効果的に期限切れにする方法

PHP にはセッションの有効期限について session.gc_maxlifetime や session.cookie_lifetime などのオプションが用意されていますが、それらは完全に信頼できるわけではありません。ここでは、独自のセッション タイムアウト メカニズムを実装するための包括的なアプローチを示します。

PHP の組み込みオプションに関する問題:

  • session.gc_maxlifetime : セッション データがいつ「ゴミ」と見なされ、セッションの開始時にクリーンアップされるかを指定します。ただし、ガベージ コレクターは散発的に実行され、デフォルトの確率はわずか 1% であり、セッションが早期に終了する可能性があります。
  • session.cookie_lifetime: このオプションは、送信されるセッション Cookie の有効期間を決定します。ブラウザに。ただし、セッション自体は無効にはならず、サーバーの責任になります。

カスタム セッション タイムアウトの実装:

セッションを期限切れにする最も効果的な方法一定期間非アクティブな状態が続いた後のセッションには、独自のタイムアウト メカニズムを実装します。これには、最後のアクティビティ (リクエスト) のタイムスタンプを維持し、リクエストごとにタイムスタンプを更新することが含まれます。最後のアクティビティが 30 分以上前である場合は、セッションの設定を解除して破棄できます。

if (isset($_SESSION['LAST_ACTIVITY']) && (time() - $_SESSION['LAST_ACTIVITY'] > 1800)) {
    // last request was more than 30 minutes ago
    session_unset(); // unset $_SESSION variable for the run-time
    session_destroy(); // destroy session data in storage
}
$_SESSION['LAST_ACTIVITY'] = time(); // update last activity time stamp

セッション データを継続的に更新することで、セッション ファイルの変更日がガベージ コレクターによって途中で削除されるのを防ぐことができます。

追加のセキュリティ対策:

セッション固定などの攻撃を防ぐには、 $_SESSION['CREATED'] タイムスタンプを更新することでセッション ID を定期的に再生成できます:

if (!isset($_SESSION['CREATED'])) {
    $_SESSION['CREATED'] = time();
} else if (time() - $_SESSION['CREATED'] > 1800) {
    // session started more than 30 minutes ago
    session_regenerate_id(true); // change session ID for the current session and invalidate old session ID
    $_SESSION['CREATED'] = time(); // update creation time
}

注:

  • session.gc_maxlifetime が設定されていることを確認してくださいカスタム有効期限ハンドラーの有効期間 (この例では 1800) 以上の値に設定します。例)。
  • アクティビティの開始後ではなく、アクティビティの 30 分後にセッションを期限切れにするには、有効期限 time() 60 * 30 を指定して setcookie を使用し、セッション Cookie をアクティブに保ちます。

以上が30 分間非アクティブになった後に PHP セッションを確実に期限切れにする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。