ASP.NET 4.0請求驗證


在客戶端文本框中輸入HTML標簽等危險內容點提交,會出現腳本錯誤:

消息: Sys.WebForms.PageRequestManagerParserErrorException: 未能分析從服務器收到的消息。

 

修改方法如下:

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

 

深入:

validateRequest=“false”是關閉驗證

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

requestValidationMode 有兩個值:

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

由於 requestValidationMode="4.0" 是強制啟用,所以我們會發現在 .NET Framework 4.0 中僅靠設置 validateRequest 是關閉不了請求驗證的,還得將 requestValidationMode 設置為 2.0。

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

而在ASP.NET4中,請求驗證默認對所有類型的請求啟動,因為它在BeginRequest被調用之前啟動,結果就是對所有資源的請求都要經過請求驗證,而不僅僅在.aspx文件和他們的類文件中,甚至包括web service和自定義的httphandler。同樣,在自定義httpmodules讀取http請求的時候,同樣要經過請求驗證。

 

更多:

如果開啟驗證,仍然可以在服務器端捕獲HttpRequestValidationException異常並加以處理(未驗證)

    protected void Page_Error(object sender, EventArgs e)
    {
        Exception ex = Server.GetLastError();
        if (ex is HttpRequestValidationException)
        {
            //處理異常
            Server.ClearError();
        }
    }


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM