„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Benötige ich „mysql_real_escape_string()“ mit vorbereiteten Anweisungen?

Benötige ich „mysql_real_escape_string()“ mit vorbereiteten Anweisungen?

Veröffentlicht am 18.11.2024
Durchsuche:870

Do I Need `mysql_real_escape_string()` with Prepared Statements?

Ist die Funktion mysql_real_escape_string() für vorbereitete Anweisungen erforderlich?

Bei Verwendung vorbereiteter Anweisungen wie in der angegebenen Abfrage:

$sql = $db->prepare('select location from location_job where location like ?');

$sql->bind_param('s', $consulta);
$sql->execute();
$sql->bind_result($location);

Die Funktion mysql_real_escape_string() ist nicht erforderlich, da vorbereitete Anweisungen eine sichere Möglichkeit bieten, SQL-Injection-Angriffe zu verhindern, indem alle Sonderzeichen in der Eingabe maskiert werden.

Ein Vorschlag zur Verbesserung der Abfrage besteht darin, das „?“ zu verwenden. Platzhalter, der es Ihnen ermöglicht, Parameter bequemer über die Ausführungsmethode zu übergeben:

$sql->execute([$consulta]);

Stellen Sie jedoch sicher, dass Benutzereingaben mit htmlspecialchars bereinigt werden () vor der Anzeige, um Cross-Site-Scripting-Schwachstellen zu verhindern.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3