⑴ sql注入截掉單引號'就沒辦法了嗎
SQL注入成功機抄率和選擇注襲入目標程序安全性有直接關系.單就你的問題和你的思路來說的話,你還可嘗試利用 ANSI 字元代碼變體來達到目的 比如 " 號對應 chr(34) .
是否成功取決於他本身程序是否也做了過濾.
另:還有很多方法同樣可以達到目的的.比如旁註、跨站、截取cookie 等
⑵ 怎麼繞過這個SQL注入後面的單引號
繞過不執行不知道怎麼寫
但可以讓where條件變成無意義的條件
arg="1' OR '1'='1";這樣c='"+"1' OR '1'='1"+"'。執行時應該就變成了
select * from table where c='1' OR '1'='1' ,判內斷條件無意義了,容即相當於 select * from table
這個網路上就有示例
⑶ 防sql注入到底應過濾哪些字元
一般來說,這樣處理即可:
所有參數都當作字元串處理,用單引號括起來。另外就是要把字元串中的單引號替換掉。
⑷ sql注入 過濾字元
不需要這么復雜。
你建一個函數,如
function saferequest(str,type)
str為參數,type為類型(1為數字)
if type =1 then
saferequest = clng(request(str))
else
saferequest = replace(request(str),"'","''")
end if
end functioin
原理:專
如果為數字型,SQL語句是這樣屬的
select * from news where id = 1
我們只要判斷參數是否為數字就行。
如果為字元型,語句類似
select * from news where news = 'ef'
如果str = ef'就會產生注入。但過涉單引號後,即無法閉合單引號,所以不會構成注入。在SQL語句中,兩個單引號代替一個單引號字元。
用法:
原先的
id = request("id")
加了函數後
id = saferequest("id",1)
⑸ jfinal 怎麼防止sql注入
數據進入資料庫之前對非法字元進行轉義,在更新和顯示的時候將非法字元還原內
在顯示的容時候對非法字元進行轉義
如果項目還處在起步階段,建議使用第二種,直接使用jstl的<c:out>標簽即可解決非法字元的問題。當然,對於Javascript還需要自己處理一下,寫一個方法,在解析從伺服器端獲取的數據時執行以下escapeHTML()即可。
⑹ 過濾單引號後是否sql注入就無解了
也不能這樣說,要過濾的內容很多,如注釋 -- ,exec delete select update 基本的都要過濾,但這不是回治本的,答如果16進制攻擊也會出問題。
最好的辦法就是使用參數方式來處理SQL,絕不要拼字元
16進制:
http://www.cnblogs.com/liyongfisher/archive/2010/12/20/1911432.html
參數化處理:
http://www.cnblogs.com/lzrabbit/archive/2012/04/21/2460978.html
⑺ 對於防止SQL注入,似乎只需把用戶輸入的單引號轉義為雙引號就可以徹底解決這個問題了
那本來的雙引號不就區分不出來了
⑻ SQL注入單引號
SqlParameter到資料庫里單引號會被轉義,所以才能有效版避免注入攻權擊。http://msdn.microsoft.com/zh-cn/library/ms161953(v=SQL.105).aspx
⑼ sql注入過程中單引號和多個關鍵字被過濾怎麼辦
很高興回答你的問題
SQL注入成功機率和選擇注入目標程序安全性有直接關系回.單就你的問題和你的思答路來說的話,你還可嘗試利用 ANSI 字元代碼變體來達到目的 比如 " 號對應 chr(34) .
是否成功取決於他本身程序是否也做了過濾.
另:還有很多方法同樣可以達到目的的.比如旁註、跨站、截取cookie 等
⑽ 大家暢所欲言,當jFinal遇到XSS和SQL注入怎麼處理
數據進入資料庫之前對非法字元進行轉義,在更新和顯示的時候將非法字元還原
在顯示的時候對非法字元進行轉義
如果項目還處在起步階段,建議使用第二種,直接使用jstl的<c:out>標簽即可解決非法字元的問題。當然,對於Javascript還需要自己處理一下,寫一個方法,在解析從伺服器端獲取的數據時執行以下escapeHTML()即可。
附:Javascript方法:
String.prototype.escapeHTML = function () {
return this.replace(/&/g, 『&』).replace(/>/g, 『>』).replace(/</g, 『<』).replace(/」/g, 『"』);
}
如果項目已經開發完成了,又不想大批量改動頁面的話,可以採用第一種方法,此時需要藉助Spring MVC的@InitBinder以及org.apache.commons.lang.PropertyEditorSupport、org.apache.commons.lang.StringEscapeUtils
public class StringEscapeEditor extends PropertyEditorSupport {
private boolean escapeHTML;
private boolean escapeJavaScript;
private boolean escapeSQL;
public StringEscapeEditor() { super(); }
public StringEscapeEditor(boolean escapeHTML, boolean escapeJavaScript, boolean escapeSQL) {
super();
this.escapeHTML = escapeHTML;
this.escapeJavaScript = escapeJavaScript;
this.escapeSQL = escapeSQL;
}
@Override
public void setAsText(String text) {
if (text == null) {
setValue(null);