ホームページ >バックエンド開発 >PHPチュートリアル >PHP セッションの有効期限とリサイクルの仕組み_PHP チュートリアル
PHP でセッションの有効期限を変更するには、PHP 設定ファイル php.ini の session.gc_maxlifetime を変更できます。
PHP がリクエストを行うたびに、1/100 の確率 (デフォルト値) で「セッションのリサイクル」がトリガーされます。 「セッションのリサイクル」が発生すると、/tmp/sess_* ファイルがチェックされ、最終変更時間が 1440 秒 (gc_maxlifetime の値) を超える場合、これらのファイルは削除されます。これは、これらのセッションが期限切れになったことを意味します。
デフォルトでは、php はセッションを /tmp ディレクトリに保存し、ファイル名は次のようになります:
sess_01aab840166fd1dc253e3b4a3f0b8381。各ファイルはセッションに対応します。
もっと見る /tmp/sess_01aab840166fd1dc253e3b4a3f0b8381
ユーザー名|s:9:”phpzixue.cn”;管理者|s:1:”0″;
#変数名|型: 長さ: 値ここでセッションファイルを削除すると、対応するセッションが無効になることを意味します。
セッションはクライアント側 (通常はブラウザー) にどのように存在しますか?
index.php?PHPSESID=01aab840166fd1dc253e3b4a3f0b8381 URL。 (サーバー側で session.use_cookies を使用して、どのメソッドが使用されるかを制御します)
サーバー側では、PHP はセッション ファイルの有効期限が切れているかどうかをどのように判断するのでしょうか?
簡単に言えば、Web サイトにログインし、1440 秒 (デフォルト値) 以内に操作がなかった場合、対応するセッションは期限切れになったと見なされます。
そのため、php.ini ファイルの gc_maxlifetime 変数を変更すると、セッションの有効期限を延長できます: (たとえば、有効期限を 86400 秒に変更します)
session.gc_maxlifetime = 86400
その後、Web サービス (通常は Apache) を再起動します。
注: PHP5 は、セッションの有効期限が切れたときにリサイクル メカニズムを使用します。ここで設定した時間は 86400 秒です。セッションが 86400 秒以内に変更されなかった場合、セッションは次の「リサイクル」まで削除されません。
セッションの「リサイクル」はいつ行われますか?
#確率は gc_probability/gc_divisor です
session.gc_probability = 1
session.gc_divisor = 100
注 1: この場合、gc_maxlifetime=120 と仮定します。セッション ファイルが最後に変更されたのが 120 秒前であれば、セッションは次のリサイクル (1/100 の確率) が発生するまで有効です。
注 2: セッションが session.save_path を使用してセッションを別の場所に保存する場合、セッションリサイクルメカニズムは期限切れのセッションファイルを自動的に処理しない可能性があります。現時点では、期限切れのセッションを定期的に手動 (または crontab) で削除する必要があります: cd
/path/to/sessions; -cmin +24 を見つけます
特別な状況
コードは 60 秒ごとにセッションの変更を試みます。
概要: セッションの有効期限を変更したい場合は、変数 gc_maxlifetime を変更するだけです。 PHP5 のセッションは、受動的なリサイクル メカニズム (ガベージ コレクション) を使用します。期限切れのセッション ファイルは自然には消えませんが、期限切れのセッションは「リサイクル」をトリガーして処理されます。
http://www.bkjia.com/PHPjc/752512.html