Heim  >  Artikel  >  Backend-Entwicklung  >  Wie führt man eine Sitzungsverwaltung in PHP durch?

Wie führt man eine Sitzungsverwaltung in PHP durch?

青灯夜游
青灯夜游Original
2019-02-14 17:40:422837Durchsuche

Das Sitzungshandling ist ein sehr wichtiges Konzept in PHP, das es ermöglicht, dass Benutzerinformationen auf allen Seiten einer Website oder Anwendung unverändert bleiben. Der folgende Artikel vermittelt Ihnen die Grundkenntnisse der Sitzungsverarbeitung in PHP. Ich hoffe, er wird Ihnen hilfreich sein.

Wie führt man eine Sitzungsverwaltung in PHP durch?

Was ist eine Sitzung in PHP?

Eine Sitzung ist ein Mechanismus zum Speichern von Informationen auf verschiedenen Webseiten, um Benutzer zu identifizieren, während sie eine Website oder Anwendung durchsuchen. [Video-Tutorial-Empfehlung: PHP-Tutorial]

Jeder muss eine Frage haben: Warum braucht die Website Sitzungen? Bevor wir dieses Problem besprechen, müssen wir noch einmal einen Blick auf die Funktionsweise des HTTP-Protokolls werfen.

Das HTTP-Protokoll ist ein zustandsloses Protokoll, was bedeutet, dass sich der Server zwischen Anfragen nicht an einen bestimmten Benutzer erinnern kann. Wenn Sie beispielsweise eine Webseite besuchen, ist der Server nur für die Bereitstellung des Inhalts der angeforderten Seite verantwortlich. Wenn Sie also andere Seiten derselben Website besuchen, interpretiert der Webserver jede Anfrage einzeln, als hätten sie nichts miteinander zu tun. Der Server kann nicht erkennen, dass jede Anfrage vom selben Benutzer stammt.

Die folgende Abbildung beschreibt kurz das HTTP-Protokoll.

Wie führt man eine Sitzungsverwaltung in PHP durch?

Wenn Sie in diesem Prozess die Informationen eines bestimmten Benutzers anzeigen möchten, müssen Sie den Benutzer bei jeder Anfrage authentifizieren. Stellen Sie sich vor, Sie müssten bei jeder Anfrage Ihren Benutzernamen und Ihr Passwort auf der Seite eingeben, um sich zu authentifizieren. Das wäre zu umständlich und überhaupt nicht praktikabel. Allerdings ist die Sitzung zu diesem Zeitpunkt praktisch.

Eine Sitzung trägt zur Aufrechterhaltung des Status bei, indem sie es Benutzern ermöglicht, Informationen über verschiedene Seiten einer einzelnen Website oder Anwendung hinweg auszutauschen. Dadurch weiß der Server, dass alle Anfragen von demselben Benutzer stammen, sodass die Site benutzerspezifische Informationen und Präferenzen anzeigen kann.

Das folgende Diagramm beschreibt, wie das HTTP-Protokoll mit Sitzungen verwendet wird.

Wie führt man eine Sitzungsverwaltung in PHP durch?

Wie geht PHP mit Sitzungen um?

1. Starten Sie die Sitzung

Wenn Sie Sitzungsvariablen verarbeiten möchten, müssen Sie sicherstellen, dass die Sitzung gestartet wurde. Es gibt mehrere Möglichkeiten, eine Sitzung in PHP zu starten.

1), verwenden Sie die Funktion „session_start“

Dies ist die gebräuchlichste Methode, bei der die Sitzung durch die Funktion „session_start“ gestartet wird.

<?php
// 启动session
session_start();
 
// 操作会话变量
?>

Es ist wichtig, dass die Funktion session_start am Anfang des Skripts aufgerufen wird, bevor eine Ausgabe an den Browser gesendet wird. Andernfalls werden Sie auf den berüchtigten Fehler „Header wurden bereits gesendet“ stoßen.

2), Sitzung automatisch starten

Wenn Sie die Sitzung in der gesamten Anwendung verwenden müssen, können Sie die Sitzung auch automatisch starten, ohne die Funktion session_start zu verwenden.

Es gibt eine Konfigurationsoption session.auto_start in der php.ini-Datei, die es uns ermöglicht, für jede Anfrage automatisch eine Sitzung zu starten. Standardmäßig ist es auf 0 eingestellt, wir können es auf 1 setzen, um die Autostart-Funktion zu aktivieren.

session.auto_start = 1

2. Sitzungs-ID abrufen

Der Server erstellt eine eindeutige ID für jede neue Sitzung. Wenn Sie die Sitzungs-ID erhalten möchten, können Sie die Funktion session_id verwenden, wie im folgenden Snippet gezeigt.

<?php
session_start();
echo session_id();
?>

Dies sollte Ihnen die aktuelle Sitzungs-ID geben. Die Funktion session_id ist interessant, weil sie auch einen Parameter annehmen kann – eine Sitzungs-ID. Wenn Sie die vom System generierte Sitzungs-ID durch Ihre eigene ersetzen möchten, können Sie sie im ersten Parameter der Funktion session_id angeben.

<?php
session_id(YOUR_SESSION_ID);
session_start();
?>

Es ist wichtig zu beachten, dass, wenn Sie eine Sitzung mit einer benutzerdefinierten Sitzungs-ID starten möchten, die Funktion session_id vor session_start aufgerufen werden muss.

3. Sitzungsvariablen erstellen

Sobald die Sitzung gestartet ist, initialisiert $_SESSION das superglobale Array mit den entsprechenden Sitzungsinformationen. Standardmäßig wird es mit einem leeren Array initialisiert. Sie können Schlüssel-Wert-Paare verwenden, um weitere Informationen zu speichern.

Sehen wir uns anhand von Codebeispielen an, wie Sitzungsvariablen initialisiert werden.

<?php
// 开启会话
session_start();
 
// 初始化会话变量
$_SESSION[&#39;logged_in_user_id&#39;] = &#39;1&#39;;
$_SESSION[&#39;logged_in_user_name&#39;] = &#39;Tutsplus&#39;;
 
// 访问会话变量
echo $_SESSION[&#39;logged_in_user_id&#39;];
echo $_SESSION[&#39;logged_in_user_name&#39;];
?>

Wie oben gezeigt, verwenden wir die Funktion session_start, um eine Sitzung am Anfang des Skripts zu starten. Anschließend initialisieren wir mehrere Sitzungsvariablen und verwenden schließlich den Superglobal $_SESSION, um auf diese Variablen zuzugreifen.

Wenn Sie den Superglobal $_SESSION zum Speichern von Daten in einer Sitzung verwenden, werden diese letztendlich in der entsprechenden Sitzungsdatei auf dem Server gespeichert, die beim Start der Sitzung erstellt wird. Auf diese Weise werden Sitzungsdaten über mehrere Anfragen hinweg gemeinsam genutzt.

Wie bereits erwähnt, werden Sitzungsinformationen zwischen Anfragen ausgetauscht, sodass auf einer Seite initialisierte Sitzungsvariablen auch von anderen Seiten aus zugänglich sind, bis die Sitzung abläuft. Normalerweise läuft die Sitzung ab, wenn der Browser geschlossen wird.

4. Sitzungsvariablen ändern und löschen

Wir können zuvor in der Anwendung erstellte Sitzungsvariablen genauso ändern oder löschen wie normale PHP-Variablen.

Nehmen wir ein Beispiel, um zu sehen, wie Sitzungsvariablen geändert werden.

<?php
session_start();
 
if (!isset($_SESSION[&#39;count&#39;]))
{
  $_SESSION[&#39;count&#39;] = 1;
}
else
{
  ++$_SESSION[&#39;count&#39;];
}
 
echo $_SESSION[&#39;count&#39;];
?>

在上面的脚本中,我们首先检查了是否设置了$_session['count']变量。如果没有设置,我们将设置为1,否则我们将增加1。因此,如果多次刷新此页,可以看到计数器每次递增一个!

另一方面,如果想要删除会话变量,可以使用unset函数,如下面的代码段所示:

<?php
// 开启会话
session_start();
 
// 初始化会话变量
$_SESSION[&#39;logged_in_user_id&#39;] = &#39;1&#39;;
 
// 取消设置会话变量
unset($_SESSION[&#39;logged_in_user_id&#39;]);
?>

这样,我们就无法再访问$_SESSION[‘logged_in_user_id’]变量了。因为它已被unset函数删除。

5、销毁会话

在上面我们知道可以使用unset函数来删除特定的会话变量;那么如果要一次删除所有与会话相关的数据,我们要怎么办?

其实很简单,我们可以使用session_destroy函数。

下面我们来看看session_destroy函数是如何工作的。

<?php
//开启会话
session_start();
 
// 假设我们已经在另一个脚本中初始化了几个会话变量
 
// 销毁此会话中的所有内容
session_destroy();
?>

说明:session_destroy函数删除存储在当前会话中的所有内容。因此,当存储在磁盘上的会话数据被session_destroy函数删除时,我们将从后续请求中看到一个空的会话变量。

注:通常,在用户注销时才会使用session_destroy函数。

以上就是本篇文章的全部内容,希望能对大家的学习有所帮助。更多精彩内容大家可以关注php中文网相关教程栏目!!!

Das obige ist der detaillierte Inhalt vonWie führt man eine Sitzungsverwaltung in PHP durch?. 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