首頁 >後端開發 >C#.Net教程 >解決asp.net中「從客戶端偵測到有潛在危險的Request.Form值」的錯誤

解決asp.net中「從客戶端偵測到有潛在危險的Request.Form值」的錯誤

伊谢尔伦
伊谢尔伦原創
2016-11-24 16:15:111166瀏覽

在提交表單時候,asp.net 提示:"從客戶端(......)中偵測到有潛在危險的 Request.Form 值" 。 asp.net中的請求驗證特性提供了某一等級的保護措施防止XSS攻擊,asp.net的請求驗證是預設啟動的。這個給出各個版本.net的解決方法。

  asp.net 2.0 通常解決方法

  方案一:

  將.aspx檔案中的page項目加入ValidateRequest="false"questcobates* #" AutoEventWireup ="true" CodeFile="test2.aspx.cs" Inherits="test2" %>  

 方案二:

  修改web.config設定檔

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

  修改web.config設定檔

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

  修改web.config設定檔

rrreee

   修改web.config設定檔是參考提交帶標籤,例如粗體 這樣的值時,ASP.NET 不會報錯。這裡推薦使用方案一,因為方案一隻修改test.aspx這一個頁面;而如果使用方案二的話,將是整個解決方案都變成ValidateRequest="false" 。

  asp.net 4.0 解決方法

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

  方法如下:

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

rrreee

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

  requestValidationMode 有兩個值:

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

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

  由於 requestValidationMode="4.0" 是強制啟用,所以我們會發現在 .NET Framework 4.0 中僅靠設定 validateRequest 是關閉不了請求驗證的,還得將 requestValidationMode 設定為 2.0。 🎜🎜🎜🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn