asp.net中“從客戶端中檢測到有潛在危險的Request.Form值”的錯誤
來源:易賢網(wǎng) 閱讀:805 次 日期:2014-08-29 10:37:39
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net中“從客戶端中檢測到有潛在危險的Request.Form值”的錯誤”,方便廣大網(wǎng)友查閱!

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

總結(jié):validateRequest 這句我們知道是關(guān)閉驗證,也就是說提交帶標簽,比如 <strong>粗體</strong> 這樣的值時,ASP.NET 不會報錯。這里推薦使用方案一,因為方案一只修改test.aspx這一個頁面;而如果使用方案二的話,將是整個解決方案都變成ValidateRequest="false" 。

asp.net 4.0 解決辦法

4.0和2.0的方法一樣,不過要注意的是從 .Net Framework 4.0 開始,asp.net開始強制檢測Request參數(shù)安全,而我們可以通過修改 Web.config 來恢復(fù) 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僅對網(wǎng)頁啟用請求驗證。是啟用還是關(guān)閉取決于 validateRequest。

•4.0 默認值。任何 HTTP 請求都會啟用請求驗證,也就是說不光是網(wǎng)頁,還包括 Cookie 等。此時強制啟用,不管 validateRequest 為何值。

由于 requestValidationMode="4.0" 是強制啟用,所以我們會發(fā)現(xiàn)在 .NET Framework 4.0 中僅靠設(shè)置 validateRequest 是關(guān)閉不了請求驗證的,還得將 requestValidationMode 設(shè)置為 2.0。

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)