Zuerst legen wir die Sitzungslebensdauer manuell fest, wie folgt:
<?php session_start(); // 保存一天 $lifeTime = 24 * 3600; setcookie(session_name(), session_id(), time() + $lifeTime, "/"); ?>
Tatsächlich stellt Session auch eine Funktion session_set_cookie_params() bereit, um die Sitzungslebensdauer festzulegen, bevor die Funktion session_start() aufgerufen wird :
<?php // 保存一天 $lifeTime = 24 * 3600; session_set_cookie_params($lifeTime); session_start(); $_SESSION["admin"] = true; ?>
Wenn der Client IE 6.0 verwendet, wird die Funktion session_set_cookie_params(); beim Setzen von Cookies einige Probleme haben, daher rufen wir die Funktion setcookie immer noch manuell auf, um Cookies zu erstellen.
Einstellung der Sitzungsablaufzeit in PHP
Viele Leute im Internet haben die Antwort gegeben: Ändern Sie session.gc_maxlifetime in der PHP-Konfigurationsdatei. Wenn Sie mehr über den Sitzungsrecyclingmechanismus erfahren möchten, lesen Sie weiter. (Die Umgebung dieses Artikels ist PHP5.2)
Übersicht: Jede PHP-Anfrage hat eine Wahrscheinlichkeit von 1/100 (Standardwert), ein „Sitzungsrecycling“ auszulösen. Wenn ein „Sitzungsrecycling“ auftritt, werden die /tmp/sess_*-Dateien überprüft. Wenn die letzte Änderungszeit 1440 Sekunden (den Wert von gc_maxlifetime) überschreitet, werden sie gelöscht, was bedeutet, dass diese Sitzungen abgelaufen sind.
1. Wie existiert eine Sitzung auf der Serverseite (normalerweise Apache mit PHP-Modul)?
Standardmäßig speichert PHP die Sitzung im Verzeichnis /tmp und der Dateiname lautet wie folgt: sess_01aab840166fd1dc253e3b4a3f0b8381. Jede Datei entspricht einer Sitzung.
more /tmp/sess_01aab840166fd1dc253e3b4a3f0b8381 username|s:9:”jiangfeng”;admin|s:1:”0″; #变量名|类型:长度:值
Das Löschen der Sitzungsdatei hier bedeutet, dass die entsprechende Sitzung ungültig ist.
(Lernvideo-Sharing: php-Video-Tutorial)
2. Wie erfolgt die Sitzung auf der Clientseite (normalerweise ein Browser)?
Die Sitzung erfolgt auf der Browserseite. Sie müssen lediglich die Sitzungs-ID (die vom Server generierte eindeutige ID) speichern. Es gibt zwei Möglichkeiten, es zu speichern: in Cookies und in URLs. Wenn die Sitzungs-ID im Cookie gespeichert ist, können Sie erkennen, dass im Cookie des Browsers eine PHPSESID-Variable vorhanden ist. Wenn es per URL übergeben wird, können Sie die URL in der Form sehen:
index.php?phpsesid=01aab840166fd1dc253e3b4a3f0b8381. (Verwenden Sie auf der Serverseite session.use_cookies, um zu steuern, welche Methode verwendet wird)
3 Wie stellt PHP auf der Serverseite fest, ob die Sitzungsdatei abgelaufen ist?
Wenn die „letzte Änderungszeit“ auf „jetzt“ gc_maxlifetime (Standard ist 1440) Sekunden überschreitet, gilt die Sitzungsdatei als abgelaufen. Wenn die Datei beim nächsten Sitzungsrecycling nicht geändert wurde, wird die Sitzungsdatei gelöscht (Sitzung läuft ab).
Einfach ausgedrückt: Wenn ich mich auf einer Website anmelde und innerhalb von 1440 Sekunden (Standardwert) keine Aktion erfolgt, gilt die entsprechende Sitzung als abgelaufen.
Ändern Sie also die Variable gc_maxlifetime in der Datei php.ini, um die Ablaufzeit der Sitzung zu verlängern: (Beispiel: Wir ändern die Ablaufzeit auf 86400 Sekunden)
session.gc_maxlifetime = 86400
Dann starten Sie Ihren Webdienst (normalerweise Apache) neu. Das war's.
Hinweis: PHP5 verwendet einen Recyclingmechanismus, wenn die Sitzung abläuft. Die hier eingestellte Zeit beträgt 86400 Sekunden. Wenn die Sitzung nicht innerhalb von 86400 Sekunden geändert wurde, wird sie erst beim nächsten „Recycling“ gelöscht.
3. Wann findet das Sitzungs-„Recycling“ statt?
Standardmäßig besteht für jede PHP-Anfrage eine Recyclingwahrscheinlichkeit von 1/100, sodass dies einfach so verstanden werden kann: „Für alle 100 PHP-Anfragen findet ein Recycling statt“. Diese Wahrscheinlichkeit wird durch die folgenden Parameter gesteuert
#概率是gc_probability/gc_divisor session.gc_probability = 1 session.gc_divisor = 100
Hinweis 1: Nehmen Sie an, dass in diesem Fall gc_maxlifetime = 120, wenn eine Sitzungsdatei zuletzt vor 120 Sekunden geändert wurde, diese Sitzung vor dem nächsten Recycling (1/100 Wahrscheinlichkeit) erfolgt ist immer noch gültig.
Hinweis 2: Wenn Ihre Sitzung session.save_path verwendet, um die Sitzung an anderer Stelle zu speichern, verarbeitet der Sitzungsrecyclingmechanismus abgelaufene Sitzungsdateien möglicherweise nicht automatisch. Zu diesem Zeitpunkt müssen Sie abgelaufene Sitzungen regelmäßig manuell (oder crontab) löschen: cd /path/to/sessions; find -cmin +24 | Time“, also wenn eine Sitzung aktiv ist, sich der Inhalt der Sitzung jedoch nicht geändert hat, Dann hat sich die entsprechende Sitzungsdatei nicht geändert. Der Recyclingmechanismus betrachtet dies als eine Sitzung, die schon lange nicht mehr aktiv war, und löscht sie. Das wollen wir nicht sehen. Wir können dieses Problem lösen, indem wir den folgenden einfachen Code hinzufügen:
<?php if(!isset($_SESSION['last_access'])||(time()-$_SESSION['last_access'])>60) $_SESSION['last_access'] = time(); ?>
Der Code wird alle 60 Sekunden versuchen, die Sitzung zu ändern.
Zusammenfassung: Wenn Sie die Ablaufzeit der Sitzung ändern möchten, ändern Sie einfach die Variable gc_maxlifetime. Die Sitzung von PHP5 verwendet einen passiven Recyclingmechanismus (Garbage Collection). Abgelaufene Sitzungsdateien verschwinden nicht von selbst, aber abgelaufene Sitzungen werden verarbeitet, indem das „Recycling“ ausgelöst wird.
Verwandte Empfehlungen:php-Einführungs-Tutorial
Das obige ist der detaillierte Inhalt vonSo ändern Sie die Sitzungsüberlebenszeit in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!