.net 2.0 4.0 表單中危險字符

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

在提交表單時候,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中「從客戶端中檢測到有潛在危險的Request.Form值」錯誤的解決辦法的用戶互動以下:asp.net

相關文章
相關標籤/搜索