首頁  >  文章  >  Java  >  jdbc怎麼防止sql注入?

jdbc怎麼防止sql注入?

藏色散人
藏色散人原創
2019-05-06 14:06:057544瀏覽

jdbc怎麼防止sql注入?

JDBC-防止sql注入漏洞 

#使用預編譯可有效防止sql的注入漏洞。

原因:在statement中不能夠有效的防止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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn