Dieser Artikel gibt Ihnen hauptsächlich eine Zusammenfassung von PHP-Sitzungen und Cookies und hofft, allen zu helfen.
1. Die Beziehung zwischen Cookie und Sitzung
Obwohl die Cookie- und Sitzungslösungen jeweils zum Client und zum Server gehören, hängt die Implementierung der serverseitigen Sitzung grob vom Cookie des Clients ab wie folgt:
1. Der Server führt den Sitzungsmechanismus aus
2. Erzeugt eine entsprechende und eindeutige Sitzungs-ID (durch Parsen und Verarbeiten dieser Sitzungs-ID kann der Server die von der Sitzung gespeicherte Datei finden und dann die Sitzungsinformationen extrahieren aus der Datei)
3. Der Server sendet diese Sitzungs-ID an den Client
Der Client empfängt die Sitzungs-ID und speichert sie in einem Cookie als Speichercontainer
4 Diese Sitzungs-ID wird jedes Mal an den Server gesendet.
Der Server analysiert die Sitzung selbst.
Hinweis: Es gibt viele Möglichkeiten, Informationen in einer Sitzung zu speichern: Cache, Datenbank, Datei usw.; Standardmäßig wird es in Dateiform gespeichert. . .
2. Der Zeitpunkt des Erstellens und Zerstörens von Sitzungen
Beim Erstellen einer Sitzung wird ein Cookie mit einem MaxAge von -1 erstellt, was bedeutet, dass es nur im Speicher vorhanden sein kann. Wenn Cookies im Browser deaktiviert sind, wird dieses Cookie trotzdem erstellt.
Wenn die vom Browser übermittelte Anfrage den jsessionid-Parameter oder den Cookie-Header enthält, erstellt der Container keine neue Sitzung mehr, sondern findet nur die vorherige Sitzung zur Zuordnung. Hier gibt es zwei Situationen:
1) Verwenden Sie jsessionid. Wenn dieser Wert einer bestehenden Sitzung entsprechen kann, wird keine neue Sitzung erstellt. Andernfalls wird trotzdem eine neue Sitzung erstellt.
2) Cookies verwenden. Wenn dieser Wert einer vorhandenen Sitzung entsprechen kann, wird keine neue Sitzung erstellt. Wenn jedoch keine entsprechende Sitzung vorhanden ist (wie nach dem Neustart des Servers oben), stellt der Container die entsprechende Sitzung basierend auf den Cookie-Informationen wieder her, als ob dies der Fall wäre war schon vorher das Gleiche.
3. Wann wird die Sitzung zerstört?
Wenn wir den Browser schließen, erneut öffnen und eine Verbindung zum Server herstellen, weist der Server eine neue Sitzung zu, was bedeutet, dass eine neue Sitzung gestartet wird. Wurde die ursprüngliche Sitzung zerstört? Ich habe ein kleines Experiment durchgeführt:
Erstellen Sie eine Sitzung:
session_start();//Registrieren Sie die Sitzungsvariable und weisen Sie $_SESSION["username"] = "hello"//Ausgabegenerierung session_idecho zu session_id();
Besuchen Sie die Seite, um eine Sitzung zu erstellen, rufen Sie die Sitzungs-ID ab, schließen Sie den Browser;
Erstellen Sie ein Sitzungsobjekt basierend auf der Sitzungs-ID
$session_id = "qpk6onnn3husvotnke030ftcm4"; session_id($session_id); session_start(); echo $_SESSION["username"]; //结果取出session
Also
Wenn der Browser geschlossen wird, wird die ursprüngliche Sitzung nicht zerstört (die Destroy-Methode wird nicht ausgeführt), sondern die Sitzung wird zerstört, bis das Timeout abläuft. Durch das Schließen des Browsers werden nur die Cookies gelöscht, die sich auf die ursprüngliche Sitzung im Speicher des Clients beziehen. Wenn der Browser erneut geöffnet wird, um eine Verbindung herzustellen, kann der Browser keine Cookie-Informationen senden, sodass der Server davon ausgeht, dass es sich um eine neue Sitzung handelt. Wenn also mit der Sitzung bestimmte Ressourcen verknüpft sind, die Sie beim Schließen des Browsers bereinigen möchten (z. B. temporäre Dateien usw.), sollten Sie eine spezifische Anfrage an den Server senden, anstatt darauf zu warten, dass die Sitzung automatisch gestartet wird aufgeräumt.
Verwandte Empfehlungen:
php implementiert die Mitglieder-Login-Registrierungsseite mit HTML plus Sitzung und Cookie
implementiert Sitzungs- und Cookie-Datenübertragung in PHP-Wertfunktion
PHP lernt den Unterschied zwischen Sitzung und Cookie
Das obige ist der detaillierte Inhalt vonTeilen von PHP-Sitzungen und Cookie-Zusammenfassungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!