JDBCでのSQLインジェクションを防ぐにはどうすればよいですか?

藏色散人
リリース: 2020-09-08 10:22:21
オリジナル
7546 人が閲覧しました

JDBCでのSQLインジェクションを防ぐにはどうすればよいですか?

JDBC - SQL インジェクションの脆弱性の防止

プリコンパイルを使用すると、SQL インジェクションの脆弱性を効果的に防止できます。

理由: SQL インジェクションの脆弱性は、ステートメントでは効果的に防止できません。これは、ユーザーがパラメーターを渡すときに、一重引用符 ' ' などの特殊文字を渡す可能性があるためです。 -- これは SQL ステートメントに影響します。

つまり、プリコンパイルでプレースホルダーを使用すると、この問題に効果的に対処できます。

public class Prepared {
@Test
public void papa(){
Connection conn = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try{
//注册驱动
// Class.forName("com.mysql.jdbc.Driver");
//建立连接
// conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/user","root","dumy");
conn =JDBCUtils.getConnection();
//编写sql代码
//String sql = "select * from administer where id = ?";
String sql = "select * from administer where username = ? and password =?";
//预编译
pstmt = conn.prepareStatement(sql);
//给? 赋值
pstmt.setString(1, "ddd");
pstmt.setString(2, "123");
rs= pstmt.executeQuery();
while(rs.next()){
System.out.println("登录成功");
}
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCUtils.release(pstmt, conn, rs);
}
}
}
ログイン後にコピー

以上がJDBCでのSQLインジェクションを防ぐにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート