首頁 > Java > java教程 > 主體

java怎麼防止sql注入?

藏色散人
發布: 2020-10-12 17:33:11
原創
12356 人瀏覽過

SQL注入是比較常見的網路攻擊方式之一,它不是利用作業系統的BUG來實現攻擊,而是針對程式設計師程式設計時的疏忽,透過SQL語句,實現無帳號登錄,甚至篡改資料庫。

java怎麼防止sql注入?

java後台防止sql注入方法:

1.採用預編譯語句集,它內建了處理SQL注入的能力,只要使用它的setString方法傳值即可:

String sql= "select * from users where username=? and password=?;
PreparedStatement preState = conn.prepareStatement(sql);
preState.setString(1, userName);
preState.setString(2, password);
ResultSet rs = preState.executeQuery();
登入後複製

2.採用正規表示式將包含有單引號('),分號(;) 和註解符號(--)的語句給替換掉來防止SQL注入

public static String SQL(String str)
{
return str.replaceAll(".*([';]+|(--)+).*", " ");
}
userName=SQL(userName);
password=SQL(password);
String sql="select * from users where username='"+userName+"' and password='"+password+"' "
Statement sta = conn.createStatement();
ResultSet rs = sta.executeQuery(sql);
登入後複製

相關推薦:《Java教學

以上是java怎麼防止sql注入?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板