Um die Sicherheitsbedenken bei der Aktualisierung von Datenbanktabellen mit nicht vertrauenswürdigen Benutzereingaben zu beseitigen, müssen wir dies verhindern SQL-Injection-Angriffe. SQL-Injection tritt auf, wenn bösartiger Code in vom Benutzer bereitgestellte Daten eingebettet und als Teil einer SQL-Abfrage ausgeführt wird.
Im angegebenen Codeausschnitt:
String insert = "INSERT INTO customer(name,address,email) VALUES('" + name + "','" + addre + "','" + email + "');";
Die Werte Name, Adresse und E-Mails stammen aus Benutzereingaben. Ein Angreifer könnte dies ausnutzen, indem er bösartigen Code wie DROP TABLE customer; in diese Werte einfügt.
Um SQL-Injection zu verhindern , ist es wichtig, die PreparedStatement-Klasse von Java zu verwenden. Diese Klasse trennt die Abfrageerstellung von der Parametereinstellung und verhindert so, dass schädlicher Code direkt in die Abfrage einbezogen wird.
String insert = "INSERT INTO customer(name,address,email) VALUES(?, ?, ?);"; PreparedStatement ps = connection.prepareStatement(insert); ps.setString(1, name); ps.setString(2, addre); ps.setString(3, email); ResultSet rs = ps.executeQuery();
Durch die Verwendung von PreparedStatement werden die vom Benutzer bereitgestellten Werte als Parameter festgelegt, anstatt an die Abfragezeichenfolge angehängt zu werden . Auf diese Weise werden sie als Daten behandelt und können nicht als bösartiger Code ausgeführt werden.
Im Kontext einer Java-GUI wo Da Benutzereingaben von JTextFields stammen, gilt das gleiche Prinzip. Die in diese Felder eingegebenen Werte sollten zur sicheren Ausführung an die PreparedStatement-Parameter übergeben werden.
Durch die Implementierung dieser Vorgehensweise können Sie SQL-Injection-Angriffe wirksam abwehren und die Sicherheit Ihrer Anwendung gewährleisten.
Das obige ist der detaillierte Inhalt vonWie können PreparedStatements in Java SQL-Injection-Schwachstellen verhindern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!