


Verwendung von Zeichenkodierungsproblemen zur Umgehung der SQL-Injection von mysql_real_escape_string()
Obwohl die mysql_real_escape_string()
-Funktion vor SQL-Injection schützt, kann sie unter bestimmten Umständen umgangen werden.
Bedenken Sie den folgenden PHP-Code:
$login = mysql_real_escape_string(GetFromPost('login')); $password = mysql_real_escape_string(GetFromPost('password')); $sql = "SELECT * FROM table WHERE login='$login' AND password='$password'";
Dieser Code scheint sicher zu sein, kann jedoch aufgrund von Randfällen bei der Zeichensatzkodierung ausgenutzt werden.
Angriffsmethode:
Der Angriff basiert auf den folgenden Schritten:
- Zeichensatz festlegen: Wählen Sie eine Codierung (z. B. gbk), bei der dieselbe Bytefolge sowohl Nicht-ASCII-Zeichen als auch ASCII-Backslash ('') darstellt.
- Erstellen der Nutzlast: Verwenden Sie eine sorgfältig konstruierte Nutzlast, die ungültige Multibyte-Zeichen enthält, und stellen Sie sicher, dass das letzte Byte einen ASCII-Backslash darstellt.
-
ruft
mysql_real_escape_string()
auf: Der Client geht davon aus, dass die Verbindung einen anderen Zeichensatz verwendet (z. B. latin1), daher fügtmysql_real_escape_string()
einen Backslash vor dem einfachen Anführungszeichen ein, was zu einer syntaktisch gültigen Zeichenfolge führt. - Abfrage senden: Die maskierte Nutzlast wird Teil der SQL-Anweisung, sodass der Angreifer beabsichtigte Schutzmaßnahmen umgehen kann.
So funktioniert es:
Das Hauptproblem besteht darin, dass der vom Server erwartete Zeichensatz nicht mit dem übereinstimmt, was der Client denkt. Obwohl mysql_real_escape_string()
gemäß der vom Client festgelegten Verbindungskodierung maskiert wird, werden ungültige Multibyte-Zeichen in einigen Fällen als einzelne Bytes behandelt, einschließlich der Fälle, in denen SET NAMES
anstelle von mysql_set_charset()
verwendet wird.
Folgen:
Dieser Angriff kann die simulierten vorbereiteten Anweisungen von PDO umgehen, selbst wenn simulierte vorbereitete Anweisungen deaktiviert sind.
Abhilfe:
Die Verwendung eines nicht anfälligen Zeichensatzes wie utf8mb4 oder utf8 kann dieses Problem mildern. Das Aktivieren des SQL-Modus NO_BACKSLASH_ESCAPES bietet ebenfalls Schutz.
Sicheres Beispiel:
Stellen Sie den Zeichensatz immer korrekt ein, indem Sie mysql_set_charset()
oder den DSN-Zeichensatzparameter von PDO verwenden. Auch echte vorbereitete Anweisungen in MySQLi sind gegen diesen Angriff immun.
Fazit:
Während mysql_real_escape_string()
im Allgemeinen einen starken Schutz bietet, ist es wichtig, sich möglicher Grenzfälle wie diesem bewusst zu sein, um einen vollständigen Schutz vor SQL-Injection zu gewährleisten.
Das obige ist der detaillierte Inhalt vonKann SQL Injection Bypass `mySQL_REAL_ESCAPE_STRING ()` Aufgrund von Zeichen für Zeichencodierung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Dieser Artikel befasst sich mit MySQLs Fehler "Die freigegebene Bibliotheksfehler". Das Problem ergibt sich aus der Unfähigkeit von MySQL, die erforderlichen gemeinsam genutzten Bibliotheken (.SO/.dll -Dateien) zu finden. Lösungen beinhalten die Überprüfung der Bibliotheksinstallation über das Paket des Systems m

In diesem Artikel wird die Optimierung von MySQL -Speicherverbrauch in Docker untersucht. Es werden Überwachungstechniken (Docker -Statistiken, Leistungsschema, externe Tools) und Konfigurationsstrategien erörtert. Dazu gehören Docker -Speichergrenzen, Tausch und CGroups neben

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

Dieser Artikel vergleicht die Installation von MySQL unter Linux direkt mit Podman -Containern mit/ohne phpmyadmin. Es beschreibt Installationsschritte für jede Methode und betont die Vorteile von Podman in Isolation, Portabilität und Reproduzierbarkeit, aber auch

Dieser Artikel bietet einen umfassenden Überblick über SQLite, eine in sich geschlossene, serverlose relationale Datenbank. Es beschreibt die Vorteile von SQLite (Einfachheit, Portabilität, Benutzerfreundlichkeit) und Nachteile (Parallelitätsbeschränkungen, Skalierbarkeitsprobleme). C

In diesem Handbuch wird die Installation und Verwaltung mehrerer MySQL -Versionen auf macOS mithilfe von Homebrew nachgewiesen. Es betont die Verwendung von Homebrew, um Installationen zu isolieren und Konflikte zu vermeiden. Der Artikel Details Installation, Starten/Stoppen von Diensten und Best PRA

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]


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

Dreamweaver Mac
Visuelle Webentwicklungstools

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software
