LoslegenKostenlos loslegen

Statements hacken

CityBook Libraries entwickelt eine Suchfunktion, mit der Nutzer Bücher nach Titel finden können. Du machst dir Sorgen um die Systemsicherheit und hast beschlossen, sie gegen SQL-Injection-Angriffe zu testen.

Prüfe, ob du mithilfe von SQL Injection unbefugt Daten abrufen kannst. Die Klasse HikariSetup ist bereits konfiguriert.

Diese Übung ist Teil des Kurses

Abfragen einer PostgreSQL-Datenbank in Java

Kurs anzeigen

Anleitung zur Übung

  • Ändere titleParameter, um eine Bedingung einzuschleusen, die das Auslesen aller Bücher ermöglicht.

Interaktive Übung

Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.

public class Main {
    public static void main(String[] args) throws SQLException {
        HikariDataSource ds = HikariSetup.createDataSource();

		// Change the title to inject a condition that will allow reading all books
        String titleParameter = "To Kill a Mockingbird";

        String query = "SELECT * FROM books WHERE title = '" +  titleParameter + "'";

        try (Connection conn = ds.getConnection()) {
            Statement stmt = conn.createStatement();
            ResultSet rs = stmt.executeQuery(query);
            while (rs.next()) {
                System.out.printf("ID: %d, Title: %s (%d)%n", rs.getInt("book_id"), rs.getString("title"), rs.getInt("publication_year"));
            }
        }
    }
}
Code bearbeiten und ausführen