Heutzutage wird es für Programmierer immer schwieriger, die Quelle zu ermitteln. Dies ist eigentlich das Gegenteil von den immer fortschrittlicheren Sprachen und zahlreichen Frameworks, die derzeit hereinströmen Sie versuchen, die ursprüngliche Verwendung so weit wie möglich zu vertuschen. Es ist so einfach, dass ich persönlich es das Programmierer-Lernparadoxon nenne.
Hinweis: Der Autor beschäftigt sich seit etwa zwei Wochen mit Webentwicklung und PHP. Der folgende Inhalt ist für Anfänger geeignet.
Dem Titel des Artikels nach zu urteilen,
Die Idee des Artikels besteht darin, zunächst zu verstehen, was eine Sitzung ist. Was ist die Verwendung von Session und wie wird Session verwendet? Was ist die Routine und wie wird sie in PHP verwendet?
Bevor Sie beginnen, empfehlen wir zunächst ein grundlegendes Theoriebuch „HTTP Authoritative Guide“, das die grundlegenden Kenntnisse für Programmierer darstellt Autor Es gibt eine elektronische Version, und Sie können bei Bedarf eine Nachricht hinterlassen.
Fast jeder ist online und Milliarden von Daten werden im Netzwerk untereinander übertragen Es basiert auf dem HTTP-Protokoll und ist sehr vertraut, oder? Tatsächlich stellt das HTTP-Protokoll eine Reihe von Methoden zur Vervollständigung Ihres Netzwerkzugriffs bereit. Wenn beide Parteien einen Zugriff herstellen, wird im Prinzip eine Sitzung eingerichtet. Nehmen wir ein Beispiel: Xiao Ming gibt https://www.baidu.com/ in den Browser ein (HTTPS ist eine verschlüsselte Version von HTTP mit einer hinzugefügten SSL-Verschlüsselungsschicht). Dies ist Xiao Mings Anfrage an Baidu und sagt: „Ich „Wenn Sie Ihre Schnittstelle sehen möchten“, empfingen die Server von Baidu die Nachricht, die enthielt, was Xiao Ming tun wollte, und auch die Adresse von Xiao Ming (sonst wüsste Baidu nicht, an wen er den Inhalt weitergeben sollte), und der Server überprüfte die Informationen OK, zeichnen Sie Xiao Mings Anfrage auf, senden Sie, was Xiao Ming will, und eine vollständige Anfrage ist beendet. Dies ist ein -Gespräch. Der Kern des Gesprächs ist die Informationsablage von Xiao Ming (tatsächlich geht es auch um TCP/IP-Verbindungsprobleme, die nichts mit diesem Artikel zu tun haben, also ignorieren Sie es) .
Tatsächlich ist es besser, einen Besuch in einer Sitzung zusammenzufassen, als eine Sitzung aufzubauen.
Wie aus dem obigen Inhalt hervorgeht, ist jeder Zugriff eine Sitzung, und der Server muss die Informationen aufzeichnen Gleichzeitig ist es nicht groß, dass dieselbe Person zehn oder zwanzig Mal nacheinander baut und spart. Das eine besteht darin, den Overhead zu erhöhen, und das andere darin, dumm zu sein. Mit anderen Worten: Eine Person (genauer gesagt derselbe Computer und Browser) kann innerhalb einer bestimmten Zeit eine Sitzung wiederverwenden. Warum innerhalb einer bestimmten Zeit? Da die Sitzung eine Standardablaufzeit hat, wird der Server nach Ablauf gelöscht (Wenn nicht, denken Sie daran, dass es so viele Menschen auf der Welt gibt, dass es eine Verschwendung wäre, jeden einzelnen zu behalten).
ok, da es sich um dieselbe Person handelt, sind mehrere Besuche eine Sitzung (zweifeln Sie nicht daran, dass der Server nicht dieselbe Person identifizieren kann, für Einzelheiten können Sie das oben empfohlene Buch lesen), und der Inhalt jedes Besuchs Sie werden alle registriert, was bedeutet, dass der Server alle Verhaltensweisen innerhalb Ihres Sitzungszyklus kennt. Dann kommt die nächste wichtige Rolle. Der Server kann dies lernen, indem er Ihre Zugriffsanfrage analysiert Präferenzen bestimmter Benutzer Durch bestimmte Analysen können wir einige Daten weitergeben, die den Benutzern am Herzen liegen. Auf diese Weise entsteht Werbe-Targeting.
Natürlich kann es andere Benutzer, Leistung usw. geben. Ich persönlich verstehe den Mechanismus nicht besonders, aber das war's hier. 3. Die Verwendung von Session in PHP Durch das obige Verb können wir feststellen, dass das Konzept der Sitzung tatsächlich auf der Serverseite auftritt.PHP bietet eine Reihe von Konfigurationen, Funktionen usw., um die Sitzungsfunktion sehr gut zu implementieren. Die Sitzungsunterstützung in PHP ist eine Methode zum Speichern bestimmter Daten beim gleichzeitigen Zugriff. Dadurch können Sie individuellere Programme erstellen und die Attraktivität Ihrer Website verbessern. Einem Besucher Ihrer Website wird eine eindeutige ID zugewiesen, die sogenannte Sitzung id. Diese ID kann in einem Cookie auf der Benutzerseite gespeichert oder über die URL übergeben werden. Die Sitzungsunterstützung ermöglicht es Ihnen, die Daten in der Anfrage im Super-Global-Array $_SESSION zu speichern Auf Ihrer Site prüft PHP automatisch (wenn session.auto_start auf 1 gesetzt ist) oder prüft auf Ihre Anfrage (explizit über session_start() oder implizit über session_register()), ob die aktuelle Sitzungs-ID durch eine zuvor gesendete Anfrage erstellt wurde Ist dies der Fall, wird die zuvor gespeicherte Umgebung neu erstellt
Durch die Zuweisung einer eindeutigen Sitzungs-ID zu jedem unabhängigen Benutzer kann die Funktion der separaten Speicherung von Daten für verschiedene Benutzer realisiert werden. Sitzungen werden häufig verwendet, um Informationen zwischen mehreren Seitenanfragen zu speichern und auszutauschen. Im Allgemeinen wird die Sitzungs-ID über ein Cookie an den Browser gesendet und die Sitzungsdaten werden auch über die Sitzungs-ID auf der Serverseite abgerufen. Wenn die Anfrage keine Sitzungs-ID-Informationen enthält, erstellt PHP eine neue Sitzung und weist der neu erstellten Sitzung eine neue ID zu.
Der Workflow von Session ist sehr einfach. Beim Starten einer Sitzung versucht PHP, die Sitzungs-ID aus der Anfrage zu ermitteln (normalerweise über das Sitzungscookie). Wenn die Anfrage keine Sitzungs-ID-Informationen enthält, erstellt PHP eine neue Sitzung. Nachdem die Sitzung gestartet wurde, setzt PHP die Daten in der Sitzung auf die Variable $_SESSION. Wenn PHP stoppt, liest es automatisch den Inhalt von $_SESSION, serialisiert ihn und sendet ihn dann zum Speichern an den Sitzungsspeichermanager. Standardmäßig verwendet PHP den integrierten Manager zum Speichern von Dateisitzungen (files
), um das Speichern der Sitzung abzuschließen. Sie können den zu verwendenden Sitzungsspeichermanager auch über das Konfigurationselement session.save_handler (Konfigurationselement in php.ini) ändern. Für den Dateisitzungs-Speichermanager werden die Sitzungsdaten an dem Speicherort gespeichert, der durch das Konfigurationselement session.save_path (Konfigurationselement in php.ini) angegeben wird. Eine Sitzung kann manuell gestartet werden, indem die Funktion session_start aufgerufen wird. Wenn das Konfigurationselement session.auto_start auf 1
gesetzt ist, wird die Sitzung automatisch gestartet, wenn die Anfrage startet. Nachdem das PHP-Skript ausgeführt wurde, wird die Sitzung automatisch geschlossen. Gleichzeitig können Sie die Sitzung auch manuell schließen, indem Sie die Funktion session_wirte_close() aufrufen.
Dieser Teil wird hier erwähnt, denn ohne die vorherige Frage zu erklären, wer weiß, wie die Konfiguration in php.ini ist. Die oben genannten session.save_handler und session.save_path sind die Konfigurationselemente in php.ini. Ich werde hier nicht näher darauf eingehen, da das PHP-Handbuch zu detailliert ist. Der Standardmodus für diesen Artikel ist „Dateien“.
session_start() ist der Beginn des Sitzungsmechanismus. Die Sitzung bestimmt, ob derzeit $_COOKIE[session_name()] zurückgegeben wird Das COOKIE, das die Session-ID speichert, wird eine Session-ID generiert und die generierte Session-ID dann als COOKIE-Wert an den Client übergeben. Im Gegensatz dazu, wenn session_id =$_COOKIE[session_name]; vorhanden ist, gehen Sie zu dem durch session.save_path angegebenen Ordner, um die Datei mit dem Namen „SESS_“ zu finden.session_id() Lesen Sie den Inhalt der Datei, deserialisieren Sie sie und führen Sie sie dann aus Legen Sie es in die Mitte von $_SESSION.
Wenn die Sitzung endet, wird der Sitzungsschreibvorgang ausgeführt oder der Vorgang session_write_close() manuell ausgeführt.
Es gibt im Allgemeinen drei Möglichkeiten, eine Sitzung im Code zu zerstören:
1. setcookie(session_name(),session_id(),time() -8000000,..); //Ausführen vor dem Abmelden
2. usset($_SESSION); //Dies löscht alle $_SESSION-Daten. Nach dem Aktualisieren wird COOKIE übergeben, es sind jedoch keine Daten vorhanden.
3. session_destroy(); //Löschen Sie $_SESSION. Löschen Sie die Sitzungsdatei und die Sitzungs-ID
Anhang, zitieren Sie am Ende einen Code aus dem Internet.
//SESSION初始化的时候调用 function open($save_path, $session_name) { global $sess_save_path; $sess_save_path=$save_path; return(true); } //关闭的时候调用 function close() { return(true); } function read($id) { global $sess_save_path; $sess_file="$sess_save_path/sess_$id"; return (string) @file_get_contents($sess_file); } //脚本执行结束之前,执行写入操作 function write($id,$sess_data) { global$sess_save_path; $sess_file="$sess_save_path/sess_$id"; if ($fp= @fopen($sess_file,"w")) { $return=fwrite($fp,$sess_data); fclose($fp); return$return; } else { return(false); } } function destroy($id) { global $sess_save_path; $sess_file="$sess_save_path/sess_$id"; return(@unlink($sess_file)); } function gc($maxlifetime) { global$sess_save_path; foreach (glob("$sess_save_path/sess_*") as$filename) { if (filemtime($filename) +$maxlifetime<time()) { @unlink($filename); } } return true; }
Das Obige ist der Inhalt der einfachen PHP-Sitzungsbeschreibung. Weitere Informationen finden Sie hier. Bitte folgen Sie der chinesischen PHP-Website (m.sbmmt.com)!