Heim  >  Artikel  >  Backend-Entwicklung  >  Verstehen Sie den SESSION-Mechanismus von PHP

Verstehen Sie den SESSION-Mechanismus von PHP

不言
不言Original
2018-04-16 15:50:321532Durchsuche

Der Hauptinhalt dieses Artikels besteht darin, den SESSION-Mechanismus von PHP zu verstehen. Jetzt kann ich ihn mit Ihnen teilen.

Verstehen Sie den SESSION-Mechanismus vollständig von PHP





1. Der Standardmechanismus verwendet Festplattendateien, um PHP-Sitzungen zu implementieren. php.ini-Konfiguration: Sitzung.save_handler =Dateien
 1 , session_start()
A. session_start() ist der Beginn des Sitzungsmechanismus, es besteht eine gewisse Wahrscheinlichkeit, die Speicherbereinigung zu starten , Da Sitzungen in Dateien gespeichert werden,
ist die SESSION-Wiederherstellung wirkungslos. Diese Wahrscheinlichkeit basiert auf PHP.
Es wird durch die Konfiguration von ini bestimmt, Aber einige Systeme sind Sitzung
.
gc_probability =0 , was bedeutet, dass die Wahrscheinlichkeit 0 ist, die Speicherbereinigung jedoch über Cron-Skripte implementiert wird. Sitzung

.
gc_probability =1Sitzung
.
gc_pisor =1000 Sitzung
.
gc_maxlifetime =1440//Die Ablaufzeit beträgt standardmäßig 24. Minuten                                                                                                                                                                                                                        // Es wird nicht empfohlen, es zu klein einzustellen. weil die Garbage Collection der Sitzung prüfen muss, ob jede Datei abgelaufen ist.

Sitzung
.save_path =//Es scheint, dass verschiedene Systeme unterschiedliche Standardeinstellungen haben.​​​​​​//Dies ist eine zufällige hierarchische Speicherung, die Sie benötigen um Ihr eigenes Skript zu schreiben

B. Die Sitzung ermittelt, ob derzeit
$_COOKIE[session_name()];session_name() gibt den COOKIE-Schlüsselwert zurück, der die session_id speichert, Dieser Wert kann von php gefunden werden.ini >
PHPSESSID
//Standardwert PHPSESSID , Wenn es nicht existiert, wird eine Sitzungs-ID, generiert und dann wird die generierte Sitzungs-ID an den Client übergeben als Wert von COOKIE
.

Dies entspricht der Ausführung der folgenden COOKIE-Operation 🎜>Vorher kann keine Ausgabe erfolgen. PHP hat eine weitere A-Funktion
session_regenerate_id() Wenn Sie diese Funktion verwenden, erfolgt vorher keine Ausgabe.  setcookie(session_name

()
,
                                                                                              🎜>.
cookie_ Lebensdauer ,//Standard 0                                                        Sitzung
. ,//Standardmäßig ist „/“ im aktuellen Programm und Verzeichnis gültig
Sitzung.cookie_domain,//
Standardmäßig leer
)  D. Wenn es existiert, dann session_id =$_COOKIE[session_name];
   Gehen Sie dann zu dem von der Sitzung angegebenen Ordner
.save_path und suchen Sie nach dem Namen 'SESS_ '.session_id() file .
Lesen Sie den Inhalt der Datei, deserialisieren Sie sie, und dann eingeben
$_SESSION


 2, sind $_SESSION-Zuweisung
 Zum Beispiel einen neuen Wert hinzufügen
$_SESSION['test'] ='blah' ; Dann wird diese $_SESSION nur im Speicher beibehalten. Wenn die Skriptausführung endet,
  schreiben Sie den Wert von
$_SESSION in den von angegebenen Ordner session_id. in und schließen Sie dann die relevanten Ressourcen . In dieser Phase ist es möglich, einen Vorgang zum Ändern der session_id auszuführen,
 Zum Beispiel: Zerstöre eine alte Sitzungs-ID und erstelle eine neue Sitzungs-ID
.Die Hälfte wird für benutzerdefinierte Sitzungsvorgänge und Rollenkonvertierung verwendet,
 Zum Beispiel Drupal
.Anonyme Benutzer von Drupal müssen eine neue Sitzungs-ID verwenden

nach der Anmeldung 3

,
if (isset($_COOKIE[session_name()])) {
            setcookie(session_name(),'',time() -42000,'/');//旧session cookie过期
          }
          session_regenerate_id();//这一步会生成新的session_id
         //session_id()返回的是新的值

SESSION-Vorgang schreiben Am Ende Mit dem Skript wird der SESSION-Schreibvorgang ausgeführt und der Wert in $_SESSION wird in die session_id mit dem Namen
in der Datei geschrieben. Möglicherweise ist sie bereits vorhanden,  muss möglicherweise erstellt werden eine neue Datei.


4. SESSION zerstören
Das von SESSION gesendete COOKIE ist im Allgemeinen ein sofortiges COOKIE und wird im Speicher gespeichert Der Browser wird geschlossen. Wenn Sie den Ablauf manuell erzwingen müssen, übergeben Sie ihn an >> Melden Sie sich ab, anstatt den Browser zu schließen. Dann müssen Sie die SESSION im Code zerstören > ()

,
Zeit() -8000000,..);//Vor dem Abmelden ausführen               2 Alle $_SESSION-Daten, nach der Aktualisierung wird COOKIE übertragen, es sind jedoch keine Daten vorhanden.      3//Diese Funktion ist gründlicher Sitzungsdatei und Sitzungs-ID
Wenn der Browser nicht geschlossen ist, aktualisieren Sie ihn erneut. Sowohl 2 als auch 3 werden COOKIE übertragen, aber die Daten können nicht gefunden werden 2. Benutzerdefinierter Sitzungsverarbeitungsmechanismus. php.ini-Konfiguration: session.save_handler =user
Benutzerdefinierte Sitzung Der Verarbeitungsmechanismus ist intuitiver
*session_set_save_handler('open','schließen','lesen','schreiben','zerstören ','gc'1
.session_start(),Execute open($save_path
,$session_name) Open Session Operations Handle .save_handler
= In Bei Dateien handelt es sich um eine Sitzung.save_path, aber wenn der Benutzer bestimmt, werden diese beiden Parameter nicht verwendet und TRUE wird zurückgegeben direkt ausführen, um read($id) auszuführen, um die Daten zu lesen //

Dieser Parameter wird automatisch übergeben zu session_id() und kann über diesen Wert bedient werden.
*2.Skriptausführung endet
Schreiben ausführen (
$id,$sess_data) //
Zwei Parameter, sehr einfach     *3.假如用户需要session_destroy()
      先执行destroy
.在执行第2步

      一个实际例子:

     

 //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)
      {
        echo"sdfsf";
        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);
          }
        }
        returntrue;
      }

相关推荐:

PHP+redis实现session共享

PHP的SESSION反序列化使用详解

php创建session方法步奏详解

Das obige ist der detaillierte Inhalt vonVerstehen Sie den SESSION-Mechanismus von PHP. 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