Heim Backend-Entwicklung PHP-Tutorial Wie kann man den Ablauf einer PHP-Sitzung nach 30 Minuten zuverlässig verwalten?

Wie kann man den Ablauf einer PHP-Sitzung nach 30 Minuten zuverlässig verwalten?

Dec 25, 2024 am 04:59 AM

How to Reliably Manage PHP Session Expiry After 30 Minutes?

<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:

  1. 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.
  2. 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']) &amp;&amp; (time() - $_SESSION['LAST_ACTIVITY'] &gt; 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
Nach dem Login kopieren
  1. Ü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.
  2. 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().
  3. 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'] &gt; 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
}
Nach dem Login kopieren

<h3>Zusätzliche Hinweise</h3>

  1. 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).
  2. 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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

11 beste PHP -URL -Shortener -Skripte (kostenlos und Premium) 11 beste PHP -URL -Shortener -Skripte (kostenlos und Premium) Mar 03, 2025 am 10:49 AM

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

Arbeiten mit Flash -Sitzungsdaten in Laravel Arbeiten mit Flash -Sitzungsdaten in Laravel Mar 12, 2025 pm 05:08 PM

Arbeiten mit Flash -Sitzungsdaten in Laravel

6 zusätzliche Fähigkeiten, die jeder PHP -Entwickler haben sollte 6 zusätzliche Fähigkeiten, die jeder PHP -Entwickler haben sollte Feb 28, 2025 am 10:52 AM

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

Verstehe Arrays in PHP Verstehe Arrays in PHP Feb 28, 2025 am 10:53 AM

Verstehe Arrays in PHP

Erstellen Sie eine React -App mit einem Laravel -Back -Ende: Teil 2, reagieren Erstellen Sie eine React -App mit einem Laravel -Back -Ende: Teil 2, reagieren Mar 04, 2025 am 09:33 AM

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

Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Mar 12, 2025 pm 05:09 PM

Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests

Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Mar 14, 2025 am 11:42 AM

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

12 Beste PHP -Chat -Skripte auf Codecanyon 12 Beste PHP -Chat -Skripte auf Codecanyon Mar 13, 2025 pm 12:08 PM

12 Beste PHP -Chat -Skripte auf Codecanyon

See all articles