Heim Datenbank MySQL-Tutorial Wie kann ich die SQL -Injektion in PHP -Anwendungen verhindern?

Wie kann ich die SQL -Injektion in PHP -Anwendungen verhindern?

Jan 25, 2025 pm 10:17 PM

How Can I Prevent SQL Injection in PHP Applications?

Verhindern Sie die SQL -Injektion von SQL in PHP

SQL -Injektion ist eine Sicherheitsanfälligkeit. Dies kann zur Ausführung eines SQL -Codes durch einen Angreifer führen, der der Anwendung katastrophale Konsequenzen verursacht.

Um die SQL -Injektion zu verhindern, ist es wichtig, die Daten von SQL zu trennen, um sicherzustellen, dass die Daten immer als Daten aufbewahrt werden, und sie wird vom SQL -Parser niemals als Befehl interpretiert. Dies kann durch die Verwendung von Sätzen mit Parametern implementiert werden. Auf diese Weise kann ein Angreifer keine böswillige SQL injizieren.

Es gibt zwei Möglichkeiten zu erreichen:

Verwenden Sie PDO (geeignet für jeden Support -Datenbank -Treiber)

Verwenden Sie MySQLI (geeignet für MySQL)

1

2

3

4

5

6

$stmt = $pdo->prepare('SELECT * FROM employees WHERE name = :name');

$stmt->execute(['name' => $name]);

 

foreach ($stmt as $row) {

    // 处理 $row

}

Nach dem Login kopieren
  • Php 8.2:

Php 8.1 und niedrigere Versionen:

1

2

3

4

$result = $db->execute_query('SELECT * FROM employees WHERE name = ?', [$name]);

while ($row = $result->fetch_assoc()) {

    // 处理 $row

}

Nach dem Login kopieren
Wenn Sie mit einer nicht -mysql -Datenbank verbunden sind, können Sie sich auf die zweite Option beziehen, die für den Treiber (z. B.

und ) von PostgreSQL spezifisch ist. PDO ist eine allgemeine Wahl.

<确> Die korrekte Verbindungskonfiguration

1

2

3

4

5

6

7

$stmt = $db-&gt;prepare('SELECT * FROM employees WHERE name = ?');

$stmt-&gt;bind_param('s', $name); // 's' 指定变量类型 -&gt; 'string'

$stmt-&gt;execute();

$result = $stmt-&gt;get_result();

while ($row = $result-&gt;fetch_assoc()) {

    // 处理 $row

}

Nach dem Login kopieren

pg_prepare() Wenn Sie PDO verwenden, um auf die MySQL -Datenbank zuzugreifen, werden reale Sätze vor der Verarbeitung standardmäßig nicht verwendet. Um dieses Problem zu lösen, ist die Simulation von Vorverarbeitungsanweisungen erforderlich. Hier finden Sie, wie Sie ein Verbindungsbeispiel mit PDO erstellen: pg_execute()

Für MySQLI muss die gleiche Operation durchgeführt werden:

<明> Erläuterung

1

2

3

4

$dbConnection = new PDO('mysql:dbname=dbtest;host=127.0.0.1;charset=utf8mb4', 'user', 'password');

 

$dbConnection-&gt;setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

$dbConnection-&gt;setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

Nach dem Login kopieren
Die SQL -Abfrage, die Sie an <您> übergeben, wird vom Datenbankserver analysiert und kompiliert. Durch Angeben von Parametern (ob

oder benennende Parameter, wie z. B. das obige Beispiel

), teilen Sie dem Datenbankkernel mit, was Sie filtern möchten. Wenn Sie dann <,> aufrufen, wird die Abfrage vor dem Verarbeitung mit den von Ihnen angegebenen Parameterwerten kombiniert.

1

2

3

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT); // 错误报告

$dbConnection = new mysqli('127.0.0.1', 'username', 'password', 'test');

$dbConnection-&gt;set_charset('utf8mb4'); // 编码

Nach dem Login kopieren

Es ist wichtig, dass der Parameterwert mit der kompilierten Abfrage kombiniert wird und nicht mit der SQL -Zeichenfolge kombiniert wird. SQL wird durch das Skript in das Skript injiziert, und die an die Datenbank gesendete SQL enthält eine böswillige Saiten, die funktionieren. Durch das Senden der tatsächlichen SQL und Parameter können Sie daher das Risiko reduzieren, Unfälle zu erhalten. Alle Parameter, die von Vorbearbeitungsanweisungen gesendet werden, werden einfach als Zeichenfolge angesehen (obwohl der Datenbankkern möglicherweise eine gewisse Optimierung durchführt, sodass die Parameter auch Zahlen sein können). Wenn im obigen Beispiel die Variable

enthält, durchsucht das Ergebnis nur die Zeichenfolge prepare und Ihre Uhr wird nicht entleert. ? :name Ein weiterer Vorteil der Verwendung der Vorverarbeitungserklärung besteht darin, dass, wenn Sie dieselbe Abfrage in derselben Sitzung ausführen, nur einmal analysieren und zusammenstellen, um die Geschwindigkeit zu verbessern. execute

Das obige ist der detaillierte Inhalt vonWie kann ich die SQL -Injektion in PHP -Anwendungen verhindern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker Reduzieren Sie die Verwendung des MySQL -Speichers im Docker Mar 04, 2025 pm 03:52 PM

Reduzieren Sie die Verwendung des MySQL -Speichers im Docker

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung? Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung? Mar 19, 2025 pm 03:51 PM

Wie verändern Sie eine Tabelle in MySQL mit der Änderungstabelleanweisung?

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen Mar 04, 2025 pm 04:01 PM

So lösen Sie das Problem der MySQL können die gemeinsame Bibliothek nicht öffnen

Was ist SQLite? Umfassende Übersicht Was ist SQLite? Umfassende Übersicht Mar 04, 2025 pm 03:55 PM

Was ist SQLite? Umfassende Übersicht

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin) Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin) Mar 04, 2025 pm 03:54 PM

Führen Sie MySQL in Linux aus (mit/ohne Podman -Container mit Phpmyadmin)

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung Mar 04, 2025 pm 03:49 PM

Ausführen mehrerer MySQL-Versionen auf macOS: Eine Schritt-für-Schritt-Anleitung

Was sind einige beliebte MySQL -GUI -Tools (z. B. MySQL Workbench, PhpMyAdmin)? Was sind einige beliebte MySQL -GUI -Tools (z. B. MySQL Workbench, PhpMyAdmin)? Mar 21, 2025 pm 06:28 PM

Was sind einige beliebte MySQL -GUI -Tools (z. B. MySQL Workbench, PhpMyAdmin)?

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)? Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)? Mar 18, 2025 pm 12:00 PM

Wie sichere ich mich MySQL gegen gemeinsame Schwachstellen (SQL-Injektion, Brute-Force-Angriffe)?

See all articles