Asp.net之?dāng)?shù)據(jù)過(guò)濾淺析
1.上傳
2.跨站
3.注入
上傳的安全問(wèn)題不在本文討論范圍內(nèi),這里只討論跨站與注入的問(wèn)題,而這兩者都是基本可以通過(guò)過(guò)濾來(lái)處理的!把注入放在最后面是因?yàn)椋琒QL注入玩了這么多年,大家應(yīng)當(dāng)有了一定的防范,只要稍有點(diǎn)注意,能在asp.net上面玩下的注入還是相當(dāng)少的!注意這以下幾點(diǎn)。
1.所有的參數(shù)。如果是int類型的,請(qǐng)轉(zhuǎn)換成int再處理! 別拿裝箱與拆箱來(lái)說(shuō)事!估計(jì)現(xiàn)在大家也不會(huì)把sql語(yǔ)句直接在web里面拼接了,起碼也要用上幾個(gè)類,中間的一些簡(jiǎn)單的邏輯處理!類型轉(zhuǎn)換還是要涉及到的
2.盡量使用參數(shù)化查詢!
3.起碼要注意過(guò)濾單引號(hào)(其實(shí)如果使用參數(shù)化查詢,不過(guò)濾也沒(méi)事,不過(guò)我還是習(xí)慣性過(guò)濾)!
?。?不要直接把錯(cuò)誤赤裸裸的暴露給用戶!這點(diǎn)不僅僅是為了防范注入,同時(shí)也是一個(gè)用戶體驗(yàn)問(wèn)題!通過(guò)重寫(xiě)OnError事件,再繼承,能很好的處理!
而相對(duì)于跨站,防洗耳范起來(lái)就麻煩多了,過(guò)濾一直是個(gè)很糾結(jié)的東西,過(guò)濾太嚴(yán)了,影響正常使用,沒(méi)過(guò)濾好,又引發(fā)安全問(wèn)題!我把我剛寫(xiě)的過(guò)濾類拿出來(lái),也許其中還有沒(méi)有考慮到的地方,希望大家指點(diǎn),
public static string StringFilters(string input)
{
if (string.IsNullOrEmpty(input))
return input;
/*跨站攻擊過(guò)慮*/
input = input.Replace("&#", "&#");//過(guò)濾&# 攻擊方式javascript:alert('XSS')
input = Regex.Replace(input, @"javascript:", "Javascript:", RegexOptions.IgnoreCase);//過(guò)濾JS 攻擊方式:javascript:alert('XSS');
input = Regex.Replace(input, @"vbscript:", "Vbscript:", RegexOptions.IgnoreCase);//過(guò)濾JS 攻擊方式:vbscript:msgbox('XSS');
input = Regex.Replace(input, @"j *a *v *a *s *c *r *i *p *t:", "Vbscript:", RegexOptions.IgnoreCase);//攻擊方式:java script:alert('XSS');
input = Regex.Replace(input, @"\/\*[sS]*\*\/", "<!-- code -->", RegexOptions.IgnoreCase);
input = Regex.Replace(input, @"expression", "expression", RegexOptions.IgnoreCase);
input = Regex.Replace(input, @"<[\u0020]*style[^>]*>", "S:yle", RegexOptions.IgnoreCase);
input = Regex.Replace(input, @"<[^>]*object[^>]*>", "objec&$58", RegexOptions.IgnoreCase);//攻擊方式 <OBJECT TYPE="text/x-scriptlet" DATA="http://www.cnblog.cn"></OBJECT> 注意,這樣過(guò)濾后將無(wú)法使用FLASH
/*各種事件過(guò)濾*/
input = Regex.Replace(input, @"<[^>]*[\u0020]+on[A-Za-z]{3,20}[\u0020]*=[\u0020]*[^>]*>", "Js Event", RegexOptions.IgnoreCase);//
input = input.Replace("'", "'");//單引號(hào)防止SQL注入
input = Regex.Replace(input, @"script", "Script", RegexOptions.IgnoreCase);//防止腳本攻擊
input = Regex.Replace(input, @"frame", "frame", RegexOptions.IgnoreCase);//防止iframe 掛馬
input = Regex.Replace(input, @"form", "form", RegexOptions.IgnoreCase);//禁止表單提交
input = Regex.Replace(input, @"meta", "meta", RegexOptions.IgnoreCase);//防止用使meta跳轉(zhuǎn)到非法網(wǎng)頁(yè)
return input;
}
補(bǔ)充一下,過(guò)濾千萬(wàn)不要把字符串過(guò)慮成空,這樣同樣存在安全問(wèn)題,必須過(guò)慮成另外一個(gè)字符串,比如過(guò)濾你好,那么用戶可以構(gòu)建這樣一個(gè)字符“你你好好”,通過(guò)Replace("你好","")之后,輸出的結(jié)果,我不說(shuō)大家也知道!
另外,這里是考慮了支持HTML的情況,所以沒(méi)有直接過(guò)慮尖括號(hào)!
- asp.NET 臟字過(guò)濾算法 修改版
- asp.NET 臟字過(guò)濾算法
- ASP.NET過(guò)濾器的應(yīng)用方法介紹
- asp.net 過(guò)濾圖片標(biāo)簽的正則
- ASP.NET環(huán)境下為網(wǎng)站增加IP過(guò)濾功能
- ASP.NET過(guò)濾HTML標(biāo)簽只保留換行與空格的方法
- ASP.NET過(guò)濾HTML字符串方法總結(jié)
- ASP.NET中的URL過(guò)濾實(shí)現(xiàn)代碼
- asp.net 臟字典過(guò)濾問(wèn)題 用正則表達(dá)式來(lái)過(guò)濾臟數(shù)據(jù)
- ASP.NET過(guò)濾類SqlFilter,防止SQL注入
- 高效.NET臟字過(guò)濾算法與應(yīng)用實(shí)例
相關(guān)文章
寫(xiě)一個(gè)含數(shù)字,拼音,漢字的驗(yàn)證碼生成類
本文和大家分享的是一個(gè)集成1:小寫(xiě)拼音;2:大寫(xiě)拼音;3:數(shù)字;4:漢字的驗(yàn)證碼生成類。本章例子也會(huì)有一個(gè)mvc使用驗(yàn)證碼校驗(yàn)的場(chǎng)景。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01詳解ASP.NET Core部署項(xiàng)目到Ubuntu Server
這篇文章主要介紹了詳解ASP.NET Core部署項(xiàng)目到Ubuntu Server ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05ASP.NET通過(guò)byte正確安全的判斷上傳文件格式
本文介紹一種更安全的方式上傳圖片,他能有效的防止一些通過(guò)修改文件后綴或MIME來(lái)偽造的圖片的上傳,從而保證服務(wù)器的安全,希望對(duì)大家有所幫助。2016-03-03ABP框架中導(dǎo)航菜單的使用及JavaScript API獲取菜單的方法
ABP框架是基于ASP.NET的Web開(kāi)發(fā)框架,其中包含基本的菜單項(xiàng)可供調(diào)用,特別是自動(dòng)生成的js API使得能夠在客戶端獲取菜單,這里我們就來(lái)看一下ABP框架中導(dǎo)航菜單的使用及JavaScript API獲取菜單的方法2016-06-06js實(shí)現(xiàn)網(wǎng)頁(yè)防止被iframe框架嵌套及幾種location.href的區(qū)別
首先我們了解一下幾種location.href的區(qū)別簡(jiǎn)單的說(shuō):幾種location.href的區(qū)別js實(shí)現(xiàn)網(wǎng)頁(yè)被iframe框架功能,感興趣的朋友可以了解下2013-08-08Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
這篇文章詳細(xì)介紹了無(wú)刷新文件上傳并顯示進(jìn)度條的思路和代碼,有需要的朋友可以參考一下2013-06-06.NET?Core企業(yè)微信網(wǎng)頁(yè)授權(quán)登錄的實(shí)現(xiàn)
本文主要介紹了.NET?Core企業(yè)微信網(wǎng)頁(yè)授權(quán)登錄的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04.NET下實(shí)現(xiàn)數(shù)字和字符相混合的驗(yàn)證碼實(shí)例
這篇文章介紹了.NET下實(shí)現(xiàn)數(shù)字和字符相混合的驗(yàn)證碼實(shí)例,有需要的朋友可以參考一下2013-11-11