Heim Backend-Entwicklung PHP-Tutorial Das Bedingungsfeld und der Tabellenfeldname in SQL sind identisch, was zu einer vollständigen Tabellenabfrage führt

Das Bedingungsfeld und der Tabellenfeldname in SQL sind identisch, was zu einer vollständigen Tabellenabfrage führt

Aug 18, 2016 am 09:15 AM
mysql php sql注入 sql语句

Hallo zusammen, ich bin ein Neuling hier. In der Praxis habe ich einen Satz gefunden, der dem folgenden ähnelt:

<code>SELECT * FROM seller_item_classify where sid=$sid order by cweight asc ;
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Wobei $sid der vom Frontend übergebene Wert ist, seller_item_classify die Angabe und sid ein Feldname in der Tabelle ist;
Wenn der von $sid übergebene Wert zufällig „sid“ ist, wird die SQL-Anweisung verwendet wird ungültig sein, was zu einer vollständigen Tabellenabfrage führt

Da der Wert von $sid in einer Produktionsumgebung ein numerischer Wert oder ein Zeichen sein kann, sollte ich den Front-End-Eingabewert in PHP filtern?

Was halten Sie von diesem Problem?

Antwortinhalt:

Hallo zusammen, ich bin ein Neuling hier. In der Praxis habe ich einen Satz gefunden, der dem folgenden ähnelt:

<code>SELECT * FROM seller_item_classify where sid=$sid order by cweight asc ;
</code>
Nach dem Login kopieren
Nach dem Login kopieren
Wobei $sid der vom Frontend übergebene Wert ist, seller_item_classify die Angabe und sid ein Feldname in der Tabelle ist;

Wenn der von $sid übergebene Wert zufällig „sid“ ist, wird die SQL-Anweisung verwendet wird ungültig sein, was zu einer vollständigen Tabellenabfrage führt
Da der Wert von $sid in einer Produktionsumgebung ein numerischer Wert oder ein Zeichen sein kann, sollte ich den Front-End-Eingabewert in PHP filtern?

Was halten Sie von diesem Problem?

<code>"SELECT * FROM seller_item_classify where sid='$sid' order by cweight asc ;"</code>
Nach dem Login kopieren
Für Front-End-Eingabewerte muss das Back-End filtern, und es wird empfohlen, die SQL-Vorverarbeitung zu verwenden.

Fügen Sie '' zu SQL-Bedingungswerten hinzu

<code>sid = '$sid'</code>
Nach dem Login kopieren

Funktioniert es?

as 别名

Fügen Sie einfache Anführungszeichen hinzu, um das Problem zu lösen

'SELECT * FROM seller_item_classify where sid='.$sid.' order by cweight asc ;'

PDO-Vorverarbeitung verwenden


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 KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

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)

So erstellen Sie Tabellen mit SQL Server mithilfe der SQL -Anweisung So erstellen Sie Tabellen mit SQL Server mithilfe der SQL -Anweisung Apr 09, 2025 pm 03:48 PM

So erstellen Sie Tabellen mithilfe von SQL -Anweisungen auf SQL Server: Öffnen Sie SQL Server Management Studio und stellen Sie eine Verbindung zum Datenbankserver her. Wählen Sie die Datenbank aus, um die Tabelle zu erstellen. Geben Sie die Anweisung "Tabelle erstellen" ein, um den Tabellennamen, den Spaltennamen, den Datentyp und die Einschränkungen anzugeben. Klicken Sie auf die Schaltfläche Ausführen, um die Tabelle zu erstellen.

So schreiben Sie ein Tutorial zum Anschließen von drei Tabellen in SQL -Anweisungen So schreiben Sie ein Tutorial zum Anschließen von drei Tabellen in SQL -Anweisungen Apr 09, 2025 pm 02:03 PM

In diesem Artikel wird ein detailliertes Tutorial zum Verbinden von drei Tabellen mithilfe von SQL -Anweisungen vorgestellt und die Leser dazu veranlasst, zu lernen, wie Daten effektiv in verschiedenen Tabellen korrelieren. Mit Beispielen und detaillierten Syntax -Erklärungen hilft Ihnen dieser Artikel dabei, die Verbindungstechniken von Tabellen in SQL zu beherrschen, damit Sie zugeordnete Informationen effizient aus der Datenbank abrufen können.

So verwenden Sie SQL Anweisung Insert So verwenden Sie SQL Anweisung Insert Apr 09, 2025 pm 06:15 PM

Die SQL Insert -Anweisung wird verwendet, um Daten in eine Tabelle einzufügen. Die Schritte umfassen: Geben Sie die Zieltabelle an, um die zu eingefügten Spalten aufzulisten. Geben Sie den zugefügten Wert an (die Reihenfolge der Werte muss dem Spaltennamen entsprechen)

So stellen Sie eine Verbindung zu einem lokalen MySQL in Navicat her So stellen Sie eine Verbindung zu einem lokalen MySQL in Navicat her Apr 09, 2025 am 07:45 AM

Um eine Verbindung zu einer lokalen MySQL -Datenbank mit Navicat herzustellen: Erstellen Sie eine Verbindung und legen Sie den Verbindungsnamen, den Host, den Port, den Benutzernamen und das Passwort fest. Testen Sie die Verbindung, um sicherzustellen, dass die Parameter korrekt sind. Speichern Sie die Verbindung. Wählen Sie eine neue Verbindung aus der Verbindungsliste aus. Doppelklicken Sie auf die Datenbank, mit der Sie eine Verbindung herstellen möchten.

Was ist der Unterschied zwischen Syntax zum Hinzufügen von Spalten in verschiedenen Datenbanksystemen Was ist der Unterschied zwischen Syntax zum Hinzufügen von Spalten in verschiedenen Datenbanksystemen Apr 09, 2025 pm 02:15 PM

不同数据库系统添加列的语法为 : MySQL : Alter table table_name add column_name data_type; postgresql : Alter table table_name add column_name data_type; oracle : Alter table table table table_name add add (column_name data_type);

Wie füge ich Spalten in SQL -grafischen Tools hinzu? Wie füge ich Spalten in SQL -grafischen Tools hinzu? Apr 09, 2025 pm 12:54 PM

Fügen Sie Spalten im SQL -Grafikwerkzeug hinzu: Wählen Sie die Tabelle aus, in die Spalten hinzugefügt werden möchten, die Sie hinzufügen möchten. Klicken Sie mit der rechten Maustaste und wählen Sie "Änderungstabelle" oder ähnliche Optionen. Definiert die Eigenschaften der neuen Spalte (Name, Datentyp, Länge oder ob es leer ist). Gibt den Standardwert für die neue Spalte gegebenenfalls an. Wählen Sie den entsprechenden Datentyp aus, um Datenfehler zu vermeiden. Verwenden Sie sinnvolle Spaltennamen. Berücksichtigen Sie die Leistungswirkung bei der Durchführung von Säulenadditionsvorgängen in großen Tabellen. Sichern Sie die Datenbank immer vor dem Vorgang, um den Datenverlust zu verhindern.

Wie man die SQL -Injektion bewertet Wie man die SQL -Injektion bewertet Apr 09, 2025 pm 04:18 PM

Zu den Methoden zur Beurteilung der SQL -Injektion gehören: Erkennen verdächtiger Eingaben, Anzeigen der ursprünglichen SQL -Anweisungen, Verwendung von Erkennungswerkzeugen, Anzeigen von Datenbankprotokollen und Durchführung von Penetrationstests. Nachdem die Injektion erkannt wurde, ergreifen Sie Maßnahmen, um Schwachstellen zu entflammen, Patches zu überprüfen, regelmäßig zu überwachen und das Bewusstsein für das Entwickler zu verbessern.

Wie füge ich Spalten in PostgreSQL hinzu? Wie füge ich Spalten in PostgreSQL hinzu? Apr 09, 2025 pm 12:36 PM

PostgreSQL Die Methode zum Hinzufügen von Spalten besteht darin, den Befehl zur Änderungstabelle zu verwenden und die folgenden Details zu berücksichtigen: Datentyp: Wählen Sie den Typ, der für die neue Spalte geeignet ist, um Daten wie int oder varchar zu speichern. Standardeinstellung: Geben Sie den Standardwert der neuen Spalte über das Standard -Schlüsselwort an und vermeiden Sie den Wert von NULL. Einschränkungen: Fügen Sie nicht null, eindeutig hinzu oder überprüfen Sie die Einschränkungen bei Bedarf. Gleichzeitige Operationen: Verwenden Sie Transaktionen oder andere Parallelitätskontrollmechanismen, um Sperrkonflikte beim Hinzufügen von Spalten zu verarbeiten.

See all articles