Heim > Datenbank > MySQL-Tutorial > Wie verhindern parametrisierte Abfragen mit Fragezeichen SQL-Injection-Angriffe?

Wie verhindern parametrisierte Abfragen mit Fragezeichen SQL-Injection-Angriffe?

Susan Sarandon
Freigeben: 2025-01-09 21:21:43
Original
435 Leute haben es durchsucht

How Do Parameterized Queries with Question Marks Prevent SQL Injection Attacks?

SQL-Injection mit parametrisierten Abfragen verhindern: Der Fragezeichen-Ansatz

Parametrierte Abfragen, die in SQL durch das Fragezeichen (?) gekennzeichnet sind, sind ein entscheidender Schutz gegen SQL-Injection-Schwachstellen. Diese Abfragen sind wichtig, wenn SQL-Anweisungen dynamisch innerhalb eines Programms erstellt und ausgeführt werden.

Der Hauptvorteil parametrisierter Abfragen gegenüber manuell erstellten Abfragen liegt in der erhöhten Sicherheit. Die Datenbankbibliothek übernimmt das Einfügen von Parametern und wendet automatisch die erforderlichen Escape-Mechanismen an, um das Einschleusen von Schadcode zu verhindern. Betrachten Sie dieses verwundbare Beispiel:

<code class="language-sql">string s = getStudentName();
cmd.CommandText = "SELECT * FROM students WHERE (name = '" + s + "')";
cmd.Execute();</code>
Nach dem Login kopieren

Wenn ein Benutzer Folgendes eingibt: Robert'); DROP TABLE students; --

Die resultierende Abfrage wird anfällig für Angriffe.

Die Lösung besteht darin, parametrisierte Abfragen zu verwenden:

<code class="language-sql">s = getStudentName();
cmd.CommandText = "SELECT * FROM students WHERE name = ?";
cmd.Parameters.Add(s);
cmd.Execute();</code>
Nach dem Login kopieren

Die Bibliothek bereinigt nun die Eingabe und macht den Schadcode unschädlich: Die Abfrage wird effektiv zu "SELECT * FROM students WHERE name = 'Robert''); DROP TABLE students; --'" – der injizierte Code wird als wörtlicher Text behandelt.

Während das Fragezeichen ein weit verbreiteter Platzhalter ist, verwenden andere Datenbanksysteme, wie z. B. MS SQL Server, benannte Parameter (z. B. @varname) für eine bessere Lesbarkeit:

<code class="language-sql">cmd.Text = "SELECT thingA FROM tableA WHERE thingB = @varname";
cmd.Parameters.AddWithValue("@varname", 7);
result = cmd.Execute();</code>
Nach dem Login kopieren

Dieser Ansatz bietet die gleichen Sicherheitsvorteile bei klarerer Parameteridentifizierung.

Das obige ist der detaillierte Inhalt vonWie verhindern parametrisierte Abfragen mit Fragezeichen SQL-Injection-Angriffe?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage