


Wie kann man den Ablauf einer PHP-Sitzung nach 30 Minuten zuverlässig verwalten?
Dec 25, 2024 am 04:59 AM<h2>So verwalten Sie den Ablauf einer PHP-Sitzung nach 30 Minuten</h2>
Die Notwendigkeit, eine Sitzung für eine bestimmte Zeit am Leben zu erhalten und sie dann zu beenden ist in der Webentwicklung üblich. PHP bietet Optionen zum Festlegen von Sitzungszeitüberschreitungen, diese liefern jedoch möglicherweise nicht immer zuverlässige Ergebnisse. Lassen Sie uns die Mängel bestehender PHP-Mechanismen verstehen und eine zuverlässige Lösung erkunden.
<h3>Zuverlässigkeitsprobleme der integrierten Timeout-Optionen von PHP</h3>
PHP bietet zwei Optionen zum Festlegen der Sitzung timeouts:
- session.gc_maxlifetime: Steuert die Anzahl der Sekunden, nach denen PHP Sitzungsdaten als „Müll“ betrachtet und die Bereinigung einleitet. Diese Option ist jedoch nicht zuverlässig, da der Garbage-Collection-Prozess von einer zufälligen Wahrscheinlichkeit abhängt, die durch session.gc_probability und session.gc_divisor bestimmt wird.
- session.cookie_lifetime: Gibt die Lebensdauer des gesendeten Cookies an zum Browser. Diese Option wirkt sich jedoch lediglich auf die Dauer des Cookies aus und macht die Sitzung selbst nicht ungültig.
<h3>Implementieren eines benutzerdefinierten Sitzungs-Timeout-Mechanismus</h3>
Um eine zuverlässige einzurichten Sitzungszeitüberschreitung, implementieren Sie Ihre eigene Lösung. Dies kann durch die Pflege eines Zeitstempels erreicht werden, der die letzte Benutzeraktivität darstellt.
if (isset($_SESSION['LAST_ACTIVITY']) && (time() - $_SESSION['LAST_ACTIVITY'] > 1800)) { // Last request was more than 30 minutes ago session_unset(); // Unset $_SESSION variable session_destroy(); // Destroy session data in storage } $_SESSION['LAST_ACTIVITY'] = time(); // Update last activity timestamp
- Überprüfen Sie, ob in der Sitzung ein „LAST_ACTIVITY“-Schlüssel vorhanden ist, und überprüfen Sie, ob seit der letzten Aktivität 30 Minuten vergangen sind.
- Wenn die Sitzung länger als 30 Minuten inaktiv war, deaktivieren Sie alle Sitzungsvariablen mit session_unset() und zerstören Sie die Sitzung mit session_destroy().
- Aktualisieren Sie regelmäßig den Zeitstempel „LAST_ACTIVITY“ bei jeder Anfrage, um die Sitzung während der aktiven Nutzung am Leben zu halten.
Da die Aktualisierung der Sitzungsdaten bei jeder Anfrage das Änderungsdatum der Sitzungsdatei ändert , wird der Garbage Collector die Sitzung nicht vorzeitig entfernen.
Für zusätzliche Sicherheit sollten Sie die Sitzungs-ID regelmäßig neu generieren Reduzieren Sie Session-Hijacking-Versuche:
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 and invalidate old one $_SESSION['CREATED'] = time(); // Update creation time }
<h3>Zusätzliche Hinweise</h3>
- Stellen Sie sicher, dass session.gc_maxlifetime auf einen Wert gesetzt ist, der größer oder gleich dem benutzerdefinierten Wert ist Dauer des Ablaufhandlers (in diesem Beispiel 1800).
- Wenn Sie ablaufen möchten Um die Sitzung basierend auf 30 Minuten Aktivität zu beenden, legen Sie mit setcookie(..., time() 60*30) einen Cookie-Ablauf fest, um das Sitzungscookie aktiv zu halten.
Das obige ist der detaillierte Inhalt vonWie kann man den Ablauf einer PHP-Sitzung nach 30 Minuten zuverlässig verwalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

11 beste PHP -URL -Shortener -Skripte (kostenlos und Premium)

Arbeiten mit Flash -Sitzungsdaten in Laravel

6 zusätzliche Fähigkeiten, die jeder PHP -Entwickler haben sollte

Erstellen Sie eine React -App mit einem Laravel -Back -Ende: Teil 2, reagieren

Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests

Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs

12 Beste PHP -Chat -Skripte auf Codecanyon
