国产欧美日韩第一页|日本一二三不卡视频|在线精品小视频,亚洲第一免费播放区,metcn人体亚洲一区,亚洲精品午夜视频

  1. 幫助中心 >  技術(shù)知識庫 >  虛擬主機 >  虛擬主機常見(jiàn)問(wèn)題及技術(shù)支持 >  asp.net中“從客戶(hù)端中檢測到有潛在危險的Request.Form值”錯誤的解決辦法

    asp.net中“從客戶(hù)端中檢測到有潛在危險的Request.Form值”錯誤的解決辦法

    2016-04-18 14:29:51 9171

    在提交表單時(shí)候,asp.net 提示:"從客戶(hù)端(......)中檢測到有?在危險的 Request.Form 值" 。asp.net中的請求驗證特性提供了某一等級的保護措施防止XSS攻擊,asp.net的請求驗證是默認啟動(dòng)的。

    這里給出不同版本.net的解決方法。

    asp.net 2.0 通常解決辦法

    方案一:

      將.aspx文件中的page項添加ValidateRequest="false" ,如下:

      <%@ Page ValidateRequest="false"  Language="C#" AutoEventWireup="true" CodeFile="test2.aspx.cs" Inherits="test2" %> 

    方案二:

      修改web.config配置文件

      <system.web>
          <pages validateRequest="false" >  
          </pages>  
      </system.web>

    總結:validateRequest 這句我們知道是關(guān)閉驗證,也就是說(shuō)提交帶標簽,比如 <strong>粗體</strong> 這樣的值時(shí),ASP.NET 不會(huì )報錯。這里推薦使用方案一,因為方案一只修改test.aspx這一個(gè)頁(yè)面;而如果使用方案二的話(huà),將是整個(gè)解決方案都變成ValidateRequest="false" 。

    asp.net 4.0 解決辦法

      4.0和2.0的方法一樣,不過(guò)要注意的是從 .Net Framework 4.0 開(kāi)始,asp.net開(kāi)始強制檢測Request參數安全,而我們可以通過(guò)修改 Web.config 來(lái)恢復 2.0 版本的模式。

      方法如下:

      修改Web.config,增加requestValidationMode="2.0"屬性值

      <system.web>
          <httpRuntime requestValidationMode="2.0" />
          <pages validateRequest="false"></pages>
      </system.web>

      4.0 中多了一個(gè) requestValidationMode,這是什么意思呢?

      requestValidationMode 有兩個(gè)值:

    2.0僅對網(wǎng)頁(yè)啟用請求驗證。是啟用還是關(guān)閉取決于validateRequest。
    4.0 默認值。任何 HTTP 請求都會(huì )啟用請求驗證,也就是說(shuō)不光是網(wǎng)頁(yè),還包括 Cookie 等。此時(shí)強制啟用,不管 validateRequest 為何值。
      由于 requestValidationMode="4.0" 是強制啟用,所以我們會(huì )發(fā)現在 .NET Framework 4.0 中僅靠設置 validateRequest 是關(guān)閉不了請求驗證的,還得將requestValidationMode 設置為 2.0。


    提交成功!非常感謝您的反饋,我們會(huì )繼續努力做到更好!

    這條文檔是否有幫助解決問(wèn)題?

    非常抱歉未能幫助到您。為了給您提供更好的服務(wù),我們很需要您進(jìn)一步的反饋信息:

    在文檔使用中是否遇到以下問(wèn)題:
    -->