suchen
HeimBackend-EntwicklungPHP-TutorialTeilen von PHP-Sitzungen und Cookie-Zusammenfassungen

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!

Stellungnahme
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
Welche Daten können in einer PHP -Sitzung gespeichert werden?Welche Daten können in einer PHP -Sitzung gespeichert werden?May 02, 2025 am 12:17 AM

PHPSSIONS CANSTORESTRINGEN, ZUGNALTEN, ARRAYS, ANDOBjekte.1.

Wie starten Sie eine PHP -Sitzung?Wie starten Sie eine PHP -Sitzung?May 02, 2025 am 12:16 AM

TostartaphpSession, useSession_start () atthescript'Sbeginning.1) PlaCEITBEFOREANYOUTPUTTOTHESESSIONSCOOKIE.2) useSsionsforuserDatalikeloginStatusOrShopingCarts

Was ist eine Sitzungsregeneration und wie verbessert es die Sicherheit?Was ist eine Sitzungsregeneration und wie verbessert es die Sicherheit?May 02, 2025 am 12:15 AM

Die Sitzung der Sitzung bezieht sich auf die Generierung einer neuen Sitzungs -ID und die Ungültigmachung der alten ID, wenn der Benutzer sensible Vorgänge bei festgelegten Sitzungsangriffen ausführt. Die Implementierungsschritte umfassen: 1. Erkennen sensibler Vorgänge, 2. Erstellen neuer Sitzungs-ID, 3..

Was sind einige Leistungsüberlegungen bei der Verwendung von PHP -Sitzungen?Was sind einige Leistungsüberlegungen bei der Verwendung von PHP -Sitzungen?May 02, 2025 am 12:11 AM

PHP -Sitzungen haben erhebliche Auswirkungen auf die Anwendungsleistung. Zu den Optimierungsmethoden gehören: 1. Verwenden Sie eine Datenbank, um Sitzungsdaten zu speichern, um die Antwortgeschwindigkeit zu verbessern; 2. Reduzieren Sie die Verwendung von Sitzungsdaten und speichern Sie nur die erforderlichen Informationen. 3.. Verwenden Sie einen nicht blockierenden Sitzungsprozessor, um die Parallelitätsfunktionen zu verbessern. 4. Passen Sie die Ablaufzeit der Sitzung an, um Benutzererfahrung und Serverbelastung auszugleichen. 5. Verwenden Sie persistente Sitzungen, um die Anzahl der Les- und Schreibzeiten zu verringern.

Wie unterscheiden sich PHP -Sitzungen von Cookies?Wie unterscheiden sich PHP -Sitzungen von Cookies?May 02, 2025 am 12:03 AM

PhpSessionsaresServer-Side, whilecookiesareclient-Side.1) SESSIsions Storedataontheserver, Aremoresecure und Handlelargerdata.2) CookieStoredataoneTheClient, AslosenSecure und LimitedInsiesindaSsibilitäts- und -Stasibilitäts- und -Stasibilitäts- und -Anssibilitäts- und -Anssibilitätsporsedataandcookiesefornonsesibel, adailliertes, adailliertes, adailliertes, adailliertes, adailliertes, addiertes-addiertes- und -Staillieren- und -Anssistieren, und -Anssibilitätsporsedaten- und -Sta- und addierta und -Anssibilitäts- und addiertes- und addailliert.

Wie identifiziert PHP die Sitzung eines Benutzers?Wie identifiziert PHP die Sitzung eines Benutzers?May 01, 2025 am 12:23 AM

PhpidentifiesAsersSSessionUsingSSessionCookiesAndSessionIDs.1) WHANE Session_Start () iscalled, phpGeneratesAuniqueSessionIDStoredInacookienMamePhpSsidontonTheusers.2) thisidallowStoretrieVessionDataFromtheServer.

Was sind einige Best Practices für die Sicherung von PHP -Sitzungen?Was sind einige Best Practices für die Sicherung von PHP -Sitzungen?May 01, 2025 am 12:22 AM

Die Sicherheit von PHP -Sitzungen kann durch folgende Maßnahmen erreicht werden: 1. Verwenden Sie Session_regenerate_id (), um die Sitzungs -ID zu regenerieren, wenn sich der Benutzer anmeldet oder eine wichtige Operation ist. 2. Verschlüsseln Sie die Übertragungssitz -ID durch das HTTPS -Protokoll. A. Verwenden Sie Session_save_path (), um das sichere Verzeichnis anzugeben, um Sitzungsdaten zu speichern und Berechtigungen korrekt festzulegen.

Wo werden standardmäßig PHP -Sitzungsdateien gespeichert?Wo werden standardmäßig PHP -Sitzungsdateien gespeichert?May 01, 2025 am 12:15 AM

PhpSessionFilesArestoredinTHedRectorySpecifiedBySession.save_path, typischerweise/tmponunix-likesystemsorc: \ windows \ temponwindows

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools