Heim Datenbank SQL Detaillierte Einführung in die SQL-Injektion

Detaillierte Einführung in die SQL-Injektion

Aug 06, 2019 pm 05:06 PM
sql

Detaillierte Einführung in die SQL-Injektion

1. Verstehen Sie zunächst das Prinzip der SQL-Injection:

SQL-Injection: Es dient zum Einfügen von SQL-Befehlen Das Web Senden Sie ein Formular oder geben Sie einen Domänennamen oder eine Abfragezeichenfolge für eine Seitenanforderung ein, wodurch der Server letztendlich dazu verleitet wird, bösartige SQL-Befehle auszuführen.

Konkret geht es um die Möglichkeit, vorhandene Anwendungen zu nutzen, um (bösartige) SQL-Befehle zur Ausführung in die Backend-Datenbank-Engine einzuschleusen. Sie kann durch die Eingabe von (böswilligen) SQL-Anweisungen in ein Webformular entstehen in der Datenbank auf der Website, anstatt SQL-Anweisungen auszuführen, wie vom Designer beabsichtigt. Beispielsweise haben viele frühere Film- und Fernsehwebsites Passwörter für VIP-Mitglieder preisgegeben, meist durch die Übermittlung von Abfragezeichen über WEB-Formulare. Solche Formulare sind besonders anfällig für SQL-Injection-Angriffe. (Quelle: Baidu)

Das heißt, die Website-Seite enthält Teile, die mit der Datenbank interagieren (z. B. die Suchfunktion einer Nachrichten-Website), und wenn Daten auf der Website eingegeben werden, werden die Daten eingegeben programmiert und zur Ausführung an die Datenbank übergeben. Während des Prozesses führten die Website-Entwickler keine Sicherheitsverarbeitung an den entsprechenden an die Datenbank übergebenen Daten durch (z. B. Filterung von Sonderzeichen, Codierung usw.), was es Hackern ermöglichte, bösartigen Code weiterzugeben (das). Dies sind SQL-Befehle, die illegale SQL-Anweisungen enthalten) über das Frontend der Website und führen diese SQL-Anweisungen für Hackerzwecke in der Datenbank aus, was zu einem Verlust von Datenbankinformationen, Schäden und anderen Folgen führt.

2. Allgemeine Klassifizierung der SQL-Injection

Klassifiziert nach Injektionspunkttyp

(1) Nummerntyp Injektionspunkt

Viele Weblinks haben eine ähnliche Struktur http://www.example.com/12.php?id=1 Injektionen, die auf dieser Form basieren, werden im Allgemeinen als digitale Injektionspunkte bezeichnet. Der Grund dafür ist B. zum Anzeigen persönlicher Benutzerinformationen, zum Anzeigen von Artikeln usw., verwenden die meisten von ihnen diese Strukturform, um IDs und andere Informationen zu übertragen und an das Backend zu übergeben Fragen Sie es aus der Datenbank ab. Die entsprechenden Informationen werden an die Rezeption zurückgesendet. Der Prototyp dieser Art von SQL-Anweisung ist wahrscheinlich „select * from table name with id=1“. =1

(2) Zeicheninjektionspunkt

Der Weblink hat eine ähnliche Struktur http://xwww.example.com/users.php?user=admin In diesem Formular ist der Benutzertyp seines Injektionspunkts ein Zeichentyp und wird daher als Zeicheninjektionspunkt bezeichnet. Der Prototyp dieser Art von SQL-Anweisung ist wahrscheinlich select * from table name where user='admin'. Es ist erwähnenswert, dass es im Vergleich zum Prototyp der SQL-Anweisung vom Typ numerische Injektion mehr Anführungszeichen gibt, die einfache oder doppelte Anführungszeichen sein können . Wenn es eine Injektion gibt, können wir für das Sprengen eine SQL-Injection-Anweisung ähnlich der folgenden erstellen: select * from table name where user='admin' and 1=1 ' Wir müssen diese lästigen Anführungszeichen loswerden.

(3) Injektionspunkt suchen

Dies ist eine besondere Art der Injektion. Diese Art der Injektion bezieht sich hauptsächlich darauf, dass die Suchparameter bei der Durchführung von Datensuchen nicht gefiltert werden. Im Allgemeinen steht „keyword=keyword“ in der Linkadresse, sondern wird direkt über das Suchfeldformular übermittelt. Der Prototyp der von dieser Art von Injektionspunkt übermittelten SQL-Anweisung lautet ungefähr: Wählen Sie * aus dem Tabellennamen aus, wobei das Feld „%keyword%“ lautet. Wenn eine Injektion vorliegt, können wir zum Sprengen eine SQL-Injektionsanweisung ähnlich der folgenden erstellen: Wählen Sie * aus Tabellenname, wobei Feld wie „%test%“ und „%1%“=„%1%“ ist

3. So ermitteln Sie, ob eine SQL-Injection vorliegt (Zusammenfassung für Anfänger, z. B Nur Referenz)

Vereinfacht ausgedrückt:

Alle Eingaben, die mit der Datenbank interagieren, können eine SQL-Injection auslösen

Die SQL-Injection basiert auf der Datenübermittlung Methoden können unterteilt werden in:

  (1) GET-Injektion : Die Methode zum Übermitteln von Daten ist GET, und die Position des Injektionspunkts befindet sich im GET-Parameterteil. Beispielsweise gibt es einen solchen Link: http://xxx.com/news.php?id=1, id ist der Injektionspunkt.

  (2) POST-Injektion : Verwenden Sie die POST-Methode, um Daten zu übermitteln. Der Injektionspunkt befindet sich im POST-Datenteil, der häufig in Formularen vorkommt.

  (3) Cookie-Injektion : HTTP-Anfragen bringen das Cookie des Clients mit, und der Injektionspunkt befindet sich in einem bestimmten Feld im Cookie.

  (4) HTTP-Header-Injektion : Der Injektionspunkt befindet sich in einem bestimmten Feld im HTTP-Anforderungsheader. Beispielsweise ist es im Feld „User-Agent“ vorhanden. Streng genommen sollte Cookie eigentlich als eine Form der Header-Injection betrachtet werden. Denn bei HTTP-Anfragen ist Cookie ein Feld im Header.

Nach der Klassifizierung nach der Übermittlungsmethode werden Sie feststellen, dass die längsten Orte, an denen SQL-Injection auftritt, Linkadressen, Datenparameter, Cookie-Informationen und HTTP-Anforderungsheader sind.

Nachdem wir die Orte verstanden haben, an denen SQL-Injection vorhanden sein kann, müssen wir bestimmen, ob SQL-Injection an diesen Orten ausgelöst werden kann. Der einfachste Weg ist die Eingabe von und 1=1 (und der transformierten Form von und 1=1). entsprechenden Ort. Bei unterschiedlichen Injektionspunkttypen müssen einfache Anführungszeichen entsprechend für Zeichentypen hinzugefügt werden, nicht jedoch für numerische Injektionspunkte.

4. Erweiterte Klassifizierung der SQL-Injection (klassifiziert nach Ausführungseffekt)

 (1) Boolesche Blindinjektion: Das heißt, die Injektionsbedingung kann anhand der zurückgegebenen Seite als wahr oder falsch beurteilt werden.

(2) Zeitbasierte Blindinjektion : Das heißt, es können keine Informationen anhand des Seitenrückgabeinhalts beurteilt werden, und bedingte Anweisungen werden verwendet, um zu überprüfen, ob die Zeitverzögerungsanweisung ausgeführt wird (das heißt, ob die Seitenrücklaufzeit zunimmt).

(3) Injektion basierend auf Fehlerberichten : Das heißt, die Seite gibt Fehlerinformationen zurück oder das Ergebnis der injizierten Anweisung wird direkt an die Seite zurückgegeben.

  (4) Union-Abfrageinjektion : Injektion im Fall einer Union kann verwendet werden.

  (5) Heap-Abfrageinjektion : Die Injektion mehrerer Anweisungen kann gleichzeitig ausgeführt werden.

(6) Wide-Byte-Injection : Die Verwendung von gbk ist eine Multibyte-Codierung, zwei Bytes repräsentieren ein chinesisches Zeichen

Dieser Artikel dient nur zum Lernen. Greifen Sie niemals in böswilliger Absicht die Websites anderer Personen an.

Empfohlene Tutorials: SQL-Online-Video-Tutorial

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in die SQL-Injektion. 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 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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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)

Was ist der Unterschied zwischen HQL und SQL im Hibernate-Framework? Was ist der Unterschied zwischen HQL und SQL im Hibernate-Framework? Apr 17, 2024 pm 02:57 PM

HQL und SQL werden im Hibernate-Framework verglichen: HQL (1. Objektorientierte Syntax, 2. Datenbankunabhängige Abfragen, 3. Typsicherheit), während SQL die Datenbank direkt betreibt (1. Datenbankunabhängige Standards, 2. Komplexe ausführbare Datei). Abfragen und Datenmanipulation).

Verwendung der Divisionsoperation in Oracle SQL Verwendung der Divisionsoperation in Oracle SQL Mar 10, 2024 pm 03:06 PM

„Verwendung der Divisionsoperation in OracleSQL“ In OracleSQL ist die Divisionsoperation eine der häufigsten mathematischen Operationen. Während der Datenabfrage und -verarbeitung können uns Divisionsoperationen dabei helfen, das Verhältnis zwischen Feldern zu berechnen oder die logische Beziehung zwischen bestimmten Werten abzuleiten. In diesem Artikel wird die Verwendung der Divisionsoperation in OracleSQL vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Zwei Arten von Divisionsoperationen in OracleSQL In OracleSQL können Divisionsoperationen auf zwei verschiedene Arten durchgeführt werden.

Vergleich und Unterschiede der SQL-Syntax zwischen Oracle und DB2 Vergleich und Unterschiede der SQL-Syntax zwischen Oracle und DB2 Mar 11, 2024 pm 12:09 PM

Oracle und DB2 sind zwei häufig verwendete relationale Datenbankverwaltungssysteme, die jeweils über ihre eigene, einzigartige SQL-Syntax und -Eigenschaften verfügen. In diesem Artikel werden die SQL-Syntax von Oracle und DB2 verglichen und unterschieden und spezifische Codebeispiele bereitgestellt. Datenbankverbindung Verwenden Sie in Oracle die folgende Anweisung, um eine Verbindung zur Datenbank herzustellen: CONNECTusername/password@database. In DB2 lautet die Anweisung zum Herstellen einer Verbindung zur Datenbank wie folgt: CONNECTTOdataba

Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Ausführliche Erläuterung der Funktion „Tag festlegen' in den dynamischen SQL-Tags von MyBatis Feb 26, 2024 pm 07:48 PM

Interpretation der dynamischen SQL-Tags von MyBatis: Detaillierte Erläuterung der Verwendung von Set-Tags. MyBatis ist ein hervorragendes Persistenzschicht-Framework. Es bietet eine Fülle dynamischer SQL-Tags und kann Datenbankoperationsanweisungen flexibel erstellen. Unter anderem wird das Set-Tag zum Generieren der SET-Klausel in der UPDATE-Anweisung verwendet, die sehr häufig bei Aktualisierungsvorgängen verwendet wird. In diesem Artikel wird die Verwendung des Set-Tags in MyBatis ausführlich erläutert und seine Funktionalität anhand spezifischer Codebeispiele demonstriert. Was ist Set-Tag? Set-Tag wird in MyBati verwendet

Was bedeutet das Identitätsattribut in SQL? Was bedeutet das Identitätsattribut in SQL? Feb 19, 2024 am 11:24 AM

Was ist Identität in SQL? In SQL ist Identität ein spezieller Datentyp, der zum Generieren automatisch inkrementierender Zahlen verwendet wird. Er wird häufig verwendet, um jede Datenzeile in einer Tabelle eindeutig zu identifizieren. Die Spalte „Identität“ wird oft in Verbindung mit der Primärschlüsselspalte verwendet, um sicherzustellen, dass jeder Datensatz eine eindeutige Kennung hat. In diesem Artikel wird die Verwendung von Identity detailliert beschrieben und es werden einige praktische Codebeispiele aufgeführt. Die grundlegende Möglichkeit, Identity zu verwenden, besteht darin, Identit beim Erstellen einer Tabelle zu verwenden.

So implementieren Sie Springboot+Mybatis-plus, ohne SQL-Anweisungen zum Hinzufügen mehrerer Tabellen zu verwenden So implementieren Sie Springboot+Mybatis-plus, ohne SQL-Anweisungen zum Hinzufügen mehrerer Tabellen zu verwenden Jun 02, 2023 am 11:07 AM

Wenn Springboot + Mybatis-plus keine SQL-Anweisungen zum Hinzufügen mehrerer Tabellen verwendet, werden die Probleme, auf die ich gestoßen bin, durch die Simulation des Denkens in der Testumgebung zerlegt: Erstellen Sie ein BrandDTO-Objekt mit Parametern, um die Übergabe von Parametern an den Hintergrund zu simulieren dass es äußerst schwierig ist, Multi-Table-Operationen in Mybatis-plus durchzuführen. Wenn Sie keine Tools wie Mybatis-plus-join verwenden, können Sie nur die entsprechende Mapper.xml-Datei konfigurieren und die stinkende und lange ResultMap konfigurieren Schreiben Sie die entsprechende SQL-Anweisung. Obwohl diese Methode umständlich erscheint, ist sie äußerst flexibel und ermöglicht es uns

So beheben Sie den 5120-Fehler in SQL So beheben Sie den 5120-Fehler in SQL Mar 06, 2024 pm 04:33 PM

Lösung: 1. Überprüfen Sie, ob der angemeldete Benutzer über ausreichende Berechtigungen zum Zugriff auf oder zum Betrieb der Datenbank verfügt, und stellen Sie sicher, dass der Benutzer über die richtigen Berechtigungen verfügt. 2. Überprüfen Sie, ob das Konto des SQL Server-Dienstes über die Berechtigung zum Zugriff auf die angegebene Datei verfügt Ordner und stellen Sie sicher, dass das Konto über ausreichende Berechtigungen zum Lesen und Schreiben der Datei oder des Ordners verfügt. 3. Überprüfen Sie, ob die angegebene Datenbankdatei von anderen Prozessen geöffnet oder gesperrt wurde. Versuchen Sie, die Datei zu schließen oder freizugeben, und führen Sie die Abfrage erneut aus . Versuchen Sie es als Administrator. Führen Sie Management Studio aus als usw.

Wie verwende ich SQL-Anweisungen zur Datenaggregation und Statistik in MySQL? Wie verwende ich SQL-Anweisungen zur Datenaggregation und Statistik in MySQL? Dec 17, 2023 am 08:41 AM

Wie verwende ich SQL-Anweisungen zur Datenaggregation und Statistik in MySQL? Datenaggregation und Statistiken sind sehr wichtige Schritte bei der Durchführung von Datenanalysen und Statistiken. Als leistungsstarkes relationales Datenbankverwaltungssystem bietet MySQL eine Fülle von Aggregations- und Statistikfunktionen, mit denen Datenaggregation und statistische Operationen problemlos durchgeführt werden können. In diesem Artikel wird die Methode zur Verwendung von SQL-Anweisungen zur Durchführung von Datenaggregation und Statistiken in MySQL vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Verwenden Sie zum Zählen die COUNT-Funktion. Die COUNT-Funktion wird am häufigsten verwendet

See all articles