国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

Asp.net之數據過濾淺析

2024-07-10 13:24:45
字體:
來源:轉載
供稿:網友
在Asp.net開如中,引發安全問題最多的大多來自于以下三個方面:
  1.上傳
  2.跨站
  3.注入
  上傳的安全問題不在本文討論范圍內,這里只討論跨站與注入的問題,而這兩者都是基本可以通過過濾來處理的!把注入放在最后面是因為,SQL注入玩了這么多年,大家應當有了一定的防范,只要稍有點注意,能在asp.net上面玩下的注入還是相當少的!注意這以下幾點。
  1.所有的參數。如果是int類型的,請轉換成int再處理! 別拿裝箱與拆箱來說事!估計現在大家也不會把sql語句直接在web里面拼接了,起碼也要用上幾個類,中間的一些簡單的邏輯處理!類型轉換還是要涉及到的
  2.盡量使用參數化查詢!
  3.起碼要注意過濾單引號(其實如果使用參數化查詢,不過濾也沒事,不過我還是習慣性過濾)!
  4.不要直接把錯誤赤裸裸的暴露給用戶!這點不僅僅是為了防范注入,同時也是一個用戶體驗問題!通過重寫OnError事件,再繼承,能很好的處理!
  而相對于跨站,防洗耳范起來就麻煩多了,過濾一直是個很糾結的東西,過濾太嚴了,影響正常使用,沒過濾好,又引發安全問題!我把我剛寫的過濾類拿出來,也許其中還有沒有考慮到的地方,希望大家指點,

復制代碼 代碼如下:


public static string StringFilters(string input)
{
if (string.IsNullOrEmpty(input))
return input;
/*跨站攻擊過慮*/
input = input.Replace("&#", "&#");//過濾&# 攻擊方式javascript:alert('XSS')
input = Regex.Replace(input, @"javascript:", "Javascript:", RegexOptions.IgnoreCase);//過濾JS 攻擊方式:javascript:alert('XSS');
input = Regex.Replace(input, @"vbscript:", "Vbscript:", RegexOptions.IgnoreCase);//過濾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, @"http:///*[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> 注意,這樣過濾后將無法使用FLASH
/*各種事件過濾*/
input = Regex.Replace(input, @"<[^>]*[/u0020]+on[A-Za-z]{3,20}[/u0020]*=[/u0020]*[^>]*>", "Js Event", RegexOptions.IgnoreCase);//
input = input.Replace("'", "'");//單引號防止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跳轉到非法網頁
return input;
}


補充一下,過濾千萬不要把字符串過慮成空,這樣同樣存在安全問題,必須過慮成另外一個字符串,比如過濾你好,那么用戶可以構建這樣一個字符“你你好好”,通過Replace("你好","")之后,輸出的結果,我不說大家也知道!
另外,這里是考慮了支持HTML的情況,所以沒有直接過慮尖括號!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 仪征市| 九龙坡区| 老河口市| 巴塘县| 吉首市| 永靖县| 全南县| 嘉义市| 静乐县| 太原市| 聊城市| 商洛市| 揭西县| 于田县| 视频| 博客| 南华县| 山丹县| 潼南县| 无极县| 德保县| 若尔盖县| 高要市| 黄骅市| 乐业县| 红河县| 朝阳市| 宿松县| 宣汉县| 灵武市| 丰镇市| 镇江市| 山阴县| 勃利县| 保康县| 泊头市| 集安市| 寿光市| 佳木斯市| 苏尼特左旗| 宁国市|