Heim > Backend-Entwicklung > PHP-Tutorial > Warum wirft „mysqli_real_escape_string()' „erwartet genau 2 Parameter, 1 gegeben'?

Warum wirft „mysqli_real_escape_string()' „erwartet genau 2 Parameter, 1 gegeben'?

Susan Sarandon
Freigeben: 2024-12-04 14:50:10
Original
441 Leute haben es durchsucht

Why Does `mysqli_real_escape_string()` Throw

Fehler „mysqli_real_escape_string() erwartet genau 2 Parameter, 1 gegeben“ wird behoben

Die Funktion „mysqli_real_escape_string()“ wurde entwickelt, um Sonderzeichen in einem String zu verhindern SQL-Injection-Angriffe. Es gibt jedoch eine bestimmte Parameteranforderung, die den Fehler „mysqli_real_escape_string() erwartet genau 2 Parameter, 1 gegeben“ verursachen kann.

Problemanalyse:

Der bereitgestellte Code prüft die PHP-Version und versucht, „mysqli_real_escape_string()“ entsprechend zu verwenden. Der Funktionsaufruf enthält jedoch nur die zu maskierende Zeichenfolge und es fehlt der erste erforderliche Parameter: der MySQL-Link.

Erklärung der Dokumentation:

Laut der offiziellen Dokumentation „mysqli_real_escape_string()“ erfordert zwei Parameter:

  1. mysqli $link: Ein Verweis auf eine hergestellte MySQLi-Verbindung.
  2. string $escapestr: Der zu seinde String entkommen.

Lösung:

Um den Fehler zu beheben, sollte der Code beim Aufruf der Funktion „mysqli_real_escape_string()“ beide Parameter enthalten. Hier ist eine aktualisierte Version:

if (phpversion() >= '4.3.0') {
    $string = mysqli_real_escape_string($link, $string);
} else {
    $string = mysqli_escape_string($link, $string);
}
Nach dem Login kopieren

Indem sichergestellt wird, dass der MySQL-Link als erster Parameter bereitgestellt wird, maskiert die Funktion „mysqli_real_escape_string()“ die Eingabezeichenfolge ordnungsgemäß und verhindert SQL-Injection-Schwachstellen.

Das obige ist der detaillierte Inhalt vonWarum wirft „mysqli_real_escape_string()' „erwartet genau 2 Parameter, 1 gegeben'?. 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