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

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

在提交表單時候,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。

以上就是告訴大家如何解決asp.net中“從客戶端中檢測到有潛在危險的Request.Form值”的錯誤辦法,希望能夠幫助到大家,小編會很開心。

您可能感興趣的文章:

ASP.NET 執行時錯誤: 沒有為副檔名“.asax”註冊的生成提供程式修正版執行asp.net時出現 http錯誤404-檔案或目錄未找到asp.net 繼承自Page實現統一頁面驗證與錯誤處理asp.net 從客戶端中檢測到有潛在危險的 Request.Form 值錯誤解asp.net 虛擬主機時常出現MAC驗證失敗錯誤之解決方法asp.net 編譯器錯誤資訊: CS0006: 未能找到後設資料檔案 該死的.NETAsp.Net 程式錯誤Runtime Error原因與解決asp.net網站的404錯誤頁面的正確設定方法asp.net執行提示未將物件引用設定到物件的例項錯誤解決方法IIS部署asp.net報404錯誤的解決方法asp.net無法載入oci.dll等錯誤的解決方法asp.net錯誤捕獲(錯誤處理)page_error事件使用方法asp.net iis7預設文件錯誤異常的解決方法ASP.Net中名稱空間Namespace淺析和使用例子ASP.NET中MVC使用AJAX呼叫JsonResult方法並返回自定義錯誤資訊asp.net操作過程中常見錯誤的解決方法ASP.NET MVC名稱空間時引起錯誤的解決方法