解決asp.net中“從用戶端中檢測到有潛在危險的Request.Form值”的錯誤

來源:互聯網
上載者:User
在提交表單時候,asp.net 提示:"從用戶端(......)中檢測到有潛在危險的 Request.Form 值" 。asp.net中的請求驗證特性提供了某一等級的保護措施防止XSS攻擊,asp.net的請求驗證是預設啟動的。這個給出各個版本.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 這句我們知道是關閉驗證,也就是說提交帶標籤,比如 <strong>粗體</strong> 這樣的值時,ASP.NET 不會報錯。這裡推薦使用方式情節一,因為方案一隻修改test.aspx這一個頁面;而如果使用方式情節二的話,將是整個解決方案都變成ValidateRequest="false" 。

  asp.net 4.0 解決辦法

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

  方法如下:

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

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

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

  requestValidationMode 有兩個值:

2.0僅對網頁啟用請求驗證。是啟用還是關閉取決於 validateRequest。

4.0 預設值。任何 HTTP 要求都會啟用請求驗證,也就是說不光是網頁,還包括 Cookie 等。此時強制啟用,不管 validateRequest 為何值。

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

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.