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
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"));
}
}
}
}