解決「檢測到有潛在危險的Request.Form值」

先看以下 web.config 的代碼:web

<system.web> 
    <compilation debug="true" targetFramework="4.0"/> 
    <httpRuntime requestValidationMode="2.0" /> 
    <pages validateRequest="false"></pages> 
</system.web>

validateRequest 這句咱們知道是關閉驗證,也就是說提交帶標籤,好比 <strong>粗體</strong> 這樣的值時,ASP.NET 不會報錯。框架

但在 4.0 中還多了一個 requestValidationMode,這是什麼意思呢?spa

requestValidationMode 有兩個值:debug

  • 2.0僅對網頁啓用請求驗證。是啓用仍是關閉取決於 validateRequest。
  • 4.0 默認值。任何 HTTP 請求都會啓用請求驗證,也就是說不光是網頁,還包括 Cookie 等。此時強制啓用,無論 validateRequest 爲什麼值。

因爲 requestValidationMode="4.0" 是強制啓用,因此咱們會發如今 .NET Framework 4.0 中僅靠設置 validateRequest 是關閉不了請求驗證的,還得將 requestValidationMode 設置爲 2.0。code

 

ASP.NET中的請求驗證特性提供了某一等級的保護措施防止XSS攻擊,以前版本的ASP.NET的請求驗證是默認啓動的,可是他牢牢應用於ASP.NET頁面中(.aspx文件和.aspx.cs文件)。orm

而在ASP.NET4中,請求驗證默認對全部類型的請求啓動,由於它在BeginRequest被調用以前啓動,結果就是對全部資源的請求都要通過請求驗證,而不單單在.aspx文件和他們的類文件中,甚至包括web service和自定義的httphandler。一樣,在自定義httpmodules讀取http請求的時候,一樣要通過請求驗證。xml

上述緣由引起的最終結果就是在ASP.NET4中會引起請求錯誤,例如檢測到有潛在危險的Request.Form值等等,爲了解決這個問題,能夠經過將驗證模式設置爲ASP.NET以前的版本。具體步驟是在web.config中加入如下配置:資源

<httpRuntime requestValidationMode=」2.0″ />get

設置了請求模式後,再設置io

<system.web>
<pages validaterequest=」false」/>
</system.web>

 

MVC框架中,在控制方法前加入:

[ValidateInput(false)]屬性。

相關文章
相關標籤/搜索