Offenlegung von PHP-Sicherheitssitzungsdaten (2)
Sitzungsdaten offengelegt
Wenn Sie sich darauf konzentrieren, die Offenlegung von Quellcode zu verhindern, sind Ihre Sitzungsdaten nur gleichermaßen gefährdet. Standardmäßig wird SESSION im Verzeichnis /tmp gespeichert. Dies ist in vielen Situationen praktisch. Eine davon ist, dass alle Benutzer Schreibberechtigungen für /tmp haben, sodass Apache auch Schreibberechtigungen hat. Während andere Benutzer diese Sitzungsdateien nicht direkt aus der Shell-Umgebung lesen können, können sie dazu ein einfaches Skript schreiben:
<?php header('Content-Type: text/plain'); session_start(); $path = ini_get('session.save_path'); $handle = dir($path); while ($filename = $handle->read()) { if (substr($filename, 0, 5) == 'sess_') { $data = file_get_contents("$path/$filename"); if (!empty($data)) { session_decode($data); $session = $_SESSION; $_SESSION = array(); echo "Session [" . substr($filename, 5) . "]\n"; print_r($session); echo "\n--\n\n"; } } } ?>
Dieses Skript sucht nach Dateien mit dem Präfix sess_ im Speicherverzeichnis der Sitzungsdatei, das durch session.save_path definiert ist. Sobald die Datei gefunden wurde, wird ihr Inhalt analysiert und mit der Funktion print_r() angezeigt. Auf diese Weise können andere Entwickler problemlos an die Sitzungsdaten Ihres Benutzers gelangen.
Der beste Weg, dieses Problem zu lösen, besteht darin, Ihre Sitzungsdaten in einer Datenbank zu speichern, die durch einen Benutzernamen und ein Passwort geschützt ist. Da der Zugriff auf die Datenbank kontrolliert wird, gibt es eine zusätzliche Schutzebene. Durch die Anwendung der im vorherigen Abschnitt erwähnten Techniken kann Ihre Datenbank einen sicheren Ort für Ihre sensiblen Daten bieten. Sie sollten jedoch wachsam bleiben, dass die Sicherheit Ihrer Datenbank immer wichtiger wird.
Um Sitzungsdaten in der Datenbank zu speichern, müssen Sie zunächst eine Datentabelle erstellen:
CREATE TABLE sessions ( id varchar(32) NOT NULL, access int(10) unsigned, data text, PRIMARY KEY (id) );
Wenn Sie MySQL verwenden, wird die Tabellenstruktur wie folgt beschrieben:
mysql> DESCRIBE sessions; +--------+------------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+------------------+------+-----+---------+-------+ | id | varchar(32) | | PRI | | | | access | int(10) unsigned | YES | | NULL | | | data | text | YES | | NULL | | +--------+------------------+------+-----+---------+-------+
Wenn Sie möchten, dass Sitzungsdaten in dieser Tabelle gespeichert werden, müssen Sie session_set_save_handler( )-Funktion zum Bearbeiten des in PHP integrierten Sitzungsmechanismus:
<?php session_set_save_handler('_open', '_close', '_read', '_write', '_destroy', '_clean'); ?>
Jedes dieser sechs Argumente ist der Name eines Funktion, die Sie schreiben müssen. Diese Funktionen erledigen die folgenden Aufgaben:
Jeder der oben genannten sechs Parameter stellt den Namen der Funktion dar, die Sie schreiben müssen:
l Sitzungsspeicher einschalten
l Sitzungsspeicher ausschalten
l Sitzungsdaten lesen
l Sitzungsdaten schreiben
l Sitzungsdaten zerstören
l Alte Sitzungsdaten löschen
Ich verwende bewusst aussagekräftige Namen, damit Sie deren Zweck auf einen Blick erkennen können. Die Benennung ist willkürlich, Sie können jedoch mit einem Unterstrich (wie hier gezeigt) oder einer anderen Namenskonvention beginnen, um Namenskonflikte zu vermeiden. Hier sind Beispiele für diese Funktionen (unter Verwendung von MySQL):
<?php function _open() { global $_sess_db; $db_user = $_SERVER['DB_USER']; $db_pass = $_SERVER['DB_PASS']; $db_host = 'localhost'; if ($_sess_db = mysql_connect($db_host, $db_user, $db_pass)) { return mysql_select_db('sessions', $_sess_db); } return FALSE; } function _close() { global $_sess_db; return mysql_close($_sess_db); } function _read($id) { global $_sess_db; $id = mysql_real_escape_string($id); $sql = "SELECT data FROM sessions WHERE id = '$id'"; if ($result = mysql_query($sql, $_sess_db)) { if (mysql_num_rows($result)) { $record = mysql_fetch_assoc($result); return $record['data']; } } return ''; } function _write($id, $data) { global $_sess_db; $access = time(); $id = mysql_real_escape_string($id); $access = mysql_real_escape_string($access); $data = mysql_real_escape_string($data); $sql = "REPLACE INTO sessions VALUES ('$id', '$access', '$data')"; return mysql_query($sql, $_sess_db); } function _destroy($id) { global $_sess_db; $id = mysql_real_escape_string($id); $sql = "DELETE FROM sessions WHERE id = '$id'"; return mysql_query($sql, $_sess_db); } function _clean($max) { global $_sess_db; $old = time() - $max; $old = mysql_real_escape_string($old); $sql = "DELETE FROM sessions WHERE access < '$old'"; return mysql_query($sql, $_sess_db); } ?>
Sie müssen session_set_save_handler() vor session_start() aufrufen ) Funktionen, aber Sie können die Funktionen selbst überall definieren.
Das Schöne an diesem Prozess ist, dass Sie den Code nicht bearbeiten oder die Art und Weise ändern müssen, wie Sie Sitzungen verwenden. $_SESSION existiert immer noch, das Verhalten bleibt gleich, PHP generiert und liefert weiterhin Sitzungskennungen und Konfigurationsänderungen im Zusammenhang mit der Sitzung werden ebenfalls wirksam. Alles, was Sie tun müssen, ist, diese eine Funktion aufzurufen (und alle darin angegebenen Funktionen zu erstellen), und PHP kümmert sich um den Rest.
Das Obige ist der Inhalt von PHP Security - Session Data Exposure (2). Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

Wenn Sie ein erfahrener PHP-Entwickler sind, haben Sie möglicherweise das Gefühl, dass Sie dort waren und dies bereits getan haben. Sie haben eine beträchtliche Anzahl von Anwendungen entwickelt, Millionen von Codezeilen debuggt und eine Reihe von Skripten optimiert, um op zu erreichen

Dieses Tutorial zeigt, wie XML -Dokumente mit PHP effizient verarbeitet werden. XML (Extensible Markup-Sprache) ist eine vielseitige textbasierte Markup-Sprache, die sowohl für die Lesbarkeit des Menschen als auch für die Analyse von Maschinen entwickelt wurde. Es wird üblicherweise für die Datenspeicherung ein verwendet und wird häufig verwendet

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Eine Zeichenfolge ist eine Folge von Zeichen, einschließlich Buchstaben, Zahlen und Symbolen. In diesem Tutorial wird lernen, wie Sie die Anzahl der Vokale in einer bestimmten Zeichenfolge in PHP unter Verwendung verschiedener Methoden berechnen. Die Vokale auf Englisch sind a, e, i, o, u und sie können Großbuchstaben oder Kleinbuchstaben sein. Was ist ein Vokal? Vokale sind alphabetische Zeichen, die eine spezifische Aussprache darstellen. Es gibt fünf Vokale in Englisch, einschließlich Großbuchstaben und Kleinbuchstaben: a, e, ich, o, u Beispiel 1 Eingabe: String = "TutorialPoint" Ausgabe: 6 erklären Die Vokale in der String "TutorialPoint" sind u, o, i, a, o, ich. Insgesamt gibt es 6 Yuan

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.

Was sind die magischen Methoden von PHP? Zu den magischen Methoden von PHP gehören: 1. \ _ \ _ Konstrukt, verwendet, um Objekte zu initialisieren; 2. \ _ \ _ Destruct, verwendet zur Reinigung von Ressourcen; 3. \ _ \ _ Call, behandeln Sie nicht existierende Methodenaufrufe; 4. \ _ \ _ GET, Implementieren Sie den dynamischen Attributzugriff; 5. \ _ \ _ Setzen Sie dynamische Attributeinstellungen. Diese Methoden werden in bestimmten Situationen automatisch aufgerufen, wodurch die Code -Flexibilität und -Effizienz verbessert werden.
