.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

相关文章
相关标签/搜索