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

首頁(yè) > 編程 > .NET > 正文

asp.net4.0框架下驗(yàn)證機(jī)制失效的原因及處理辦法

2024-07-10 12:45:14
字體:
供稿:網(wǎng)友

ASP.NET請(qǐng)求驗(yàn)證功能為我們提供應(yīng)用程序的安全保證,避免站點(diǎn)受到XSS跨站腳本攻擊。但在有些時(shí)候,比如我們需要使用Ckeditor等在線文本編輯器讓用戶輸入一些HTML文本,在ASP.NET 2.0框架下,通過在web.config中設(shè)置validateRequest="false"?;蛘咴贛VC中,我們可以通過在Controller或者Action上設(shè)置[ValidateRequest(false)]這個(gè)特性來達(dá)到禁用的目的。但是在ASP.NET 4.0框架下,你會(huì)發(fā)現(xiàn),即使你這樣做,仍然會(huì)提示你這樣的一個(gè)異?!癆 potentially dangerous Request.Form value was detected from the client”。這是怎么回事呢?

原來是asp.net4.0應(yīng)用程序生命周期發(fā)生了變化,在之前的ASP.NET版本中,請(qǐng)求驗(yàn)證是默認(rèn)啟用的,但是它只對(duì)頁(yè)面請(qǐng)求有效(請(qǐng)求.aspx頁(yè)面),并且也只是在頁(yè)面被請(qǐng)求時(shí)驗(yàn)證。但是在ASP.NET 4.0中,請(qǐng)求驗(yàn)證功能被提前到IHttpHandler.BeginRequest這個(gè)方法被請(qǐng)求之前,這也就意味著所有進(jìn)入ASP.NET請(qǐng)求通道的所有的HTTP請(qǐng)求都將會(huì)被進(jìn)行請(qǐng)求內(nèi)容合法性的驗(yàn)證,包括有的自定義HttpHandler,WebService請(qǐng)求,甚至于利用自定義Http Module進(jìn)行自定義請(qǐng)求處理程序。

請(qǐng)求驗(yàn)證處理被提前的后果就是導(dǎo)致我們?cè)陧?yè)面,或者Controller中設(shè)置ValidateRequest=false,將會(huì)失效,無法阻止程序不去驗(yàn)證請(qǐng)求的輸入內(nèi)容了。因?yàn)檫@樣做后,驗(yàn)證器無法得到請(qǐng)求的頁(yè)面是否禁用了驗(yàn)證請(qǐng)求,因?yàn)檫€沒有實(shí)例化HttpHandler。并且在ASP.NET4.0中,并沒有提供給我一個(gè)地方去禁用這個(gè)驗(yàn)證功能。但是出于兼容性的考慮,ASP.NET允許我們通過在web.config中配置使用ASP.NET 2.0的請(qǐng)求驗(yàn)證行為:<httpRuntime requestValidationMode=”2.0″ />,這樣就解決了。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 新安县| 遵义市| 池州市| 房产| 汽车| 华阴市| 永吉县| 宝清县| 肇州县| 沙田区| 双峰县| 安丘市| 个旧市| 民丰县| 虹口区| 岳西县| 息烽县| 龙胜| 洪雅县| 张北县| 香河县| 万年县| 即墨市| 尚义县| 乐昌市| 和顺县| 丘北县| 安达市| 大邑县| 正宁县| 孝感市| 车险| 镇赉县| 寻乌县| 宁德市| 太仓市| 松原市| 米林县| 平乐县| 广昌县| 吉木萨尔县|