欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2013年06月08日 11:51:48   作者:  
asp.net4.0框架下驗(yàn)證機(jī)制失效的原因及處理辦法,需要的朋友可以參考一下

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

原來(lái)是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ì)失效,無(wú)法阻止程序不去驗(yàn)證請(qǐng)求的輸入內(nèi)容了。因?yàn)檫@樣做后,驗(yàn)證器無(wú)法得到請(qǐng)求的頁(yè)面是否禁用了驗(yàn)證請(qǐng)求,因?yàn)檫€沒(méi)有實(shí)例化HttpHandler。并且在ASP.NET4.0中,并沒(méi)有提供給我一個(gè)地方去禁用這個(gè)驗(yàn)證功能。但是出于兼容性的考慮,ASP.NET允許我們通過(guò)在web.config中配置使用ASP.NET 2.0的請(qǐng)求驗(yàn)證行為:<httpRuntime requestValidationMode=”2.0″ />,這樣就解決了。

相關(guān)文章

  • .NET?Core?Web?APi類庫(kù)內(nèi)嵌運(yùn)行的方法

    .NET?Core?Web?APi類庫(kù)內(nèi)嵌運(yùn)行的方法

    這篇文章主要介紹了.NET?Core?Web?APi類庫(kù)內(nèi)嵌運(yùn)行的方法,本節(jié)我們重點(diǎn)討論如何內(nèi)嵌運(yùn)行.NET Core Web APi類庫(kù),同時(shí)介紹了兩種激活比如控制器特性方案,需要的朋友可以參考下
    2022-09-09
  • .Net使用Cancellation?Framework取消并行任務(wù)

    .Net使用Cancellation?Framework取消并行任務(wù)

    這篇文章介紹了.Net使用Cancellation?Framework取消并行任務(wù)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • 如何在不同.net版本實(shí)現(xiàn)單點(diǎn)登錄

    如何在不同.net版本實(shí)現(xiàn)單點(diǎn)登錄

    經(jīng)過(guò)研究,重寫(xiě)實(shí)現(xiàn)了一個(gè)可以在不同.net版本中實(shí)現(xiàn)單點(diǎn)登錄的簡(jiǎn)單方法?,F(xiàn)在和大家分享一下,不足之處還望見(jiàn)諒
    2013-07-07
  • Visual Studio 2017安裝心得總結(jié)

    Visual Studio 2017安裝心得總結(jié)

    這篇文章主要為大家詳細(xì)總結(jié)了Visual Studio 2017安裝心得,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • .NET Core單元測(cè)試的兩種方法介紹

    .NET Core單元測(cè)試的兩種方法介紹

    這篇文章介紹了.NET Core單元測(cè)試的兩種方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • Asp.Net Core輕松學(xué)之利用日志監(jiān)視進(jìn)行服務(wù)遙測(cè)詳解

    Asp.Net Core輕松學(xué)之利用日志監(jiān)視進(jìn)行服務(wù)遙測(cè)詳解

    這篇文章主要給大家介紹了關(guān)于Asp.Net Core輕松學(xué)之利用日志監(jiān)視進(jìn)行服務(wù)遙測(cè)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧
    2018-12-12
  • Gridview用法大總結(jié)(全程圖解珍藏版)

    Gridview用法大總結(jié)(全程圖解珍藏版)

    Gridview用法大總結(jié)啦!精彩效果截圖加詳細(xì)源代碼注釋,需要的朋友趕緊過(guò)來(lái)看看吧
    2013-06-06
  • asp.net 中將表單提交到另一頁(yè) Code-Behind(代碼和html在不同的頁(yè)面)

    asp.net 中將表單提交到另一頁(yè) Code-Behind(代碼和html在不同的頁(yè)面)

    To send Server control values from a different Web Forms page
    2009-04-04
  • asp.net 去除viewstate

    asp.net 去除viewstate

    生成了這么多的一段東西,這段東西對(duì)seo一點(diǎn)好處也沒(méi)有。而我要做的就是去掉它,但有一點(diǎn),去掉但不能讓它原來(lái)的控件和內(nèi)容都發(fā)生變化
    2009-03-03
  • 詳解.net core日記記錄

    詳解.net core日記記錄

    這篇文章主要介紹了.net core的日記記錄,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04

最新評(píng)論