asp.net中“从客户端中检测到有潜在危险的Request.Form值”错误的解决办法

 更新时间:2021年08月20日 15:53:14   投稿:lijiao  
这篇文章主要介绍了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中绑定TextBox回车事件的解决方法

    asp.net中绑定TextBox回车事件的解决方法

    asp.net中绑定TextBox回车事件的解决方法,需要的朋友可以参考下。
    2011-07-07
  • Asp.Net Core简介与安装教程

    Asp.Net Core简介与安装教程

    这篇文章主要为大家详细介绍了Asp.Net Core简介与安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • ASP.NET MVC中使用JavaScriptResult的用法示例

    ASP.NET MVC中使用JavaScriptResult的用法示例

    这篇文章主要介绍了ASP.NET MVC中使用JavaScriptResult的用法,结合实例形式分析了采用javascript动态设置标签样式以及使用MVC中的JavaScriptResult来实现同样效果的相关技巧,需要的朋友可以参考下
    2016-08-08
  • .NET发起web请求时维持Session

    .NET发起web请求时维持Session

    一般使用.NET C#发起一个web请求是用WebClient类,应为使用很简单,但是每调用一次OpenRead就会在服务器启用一个新Session,使用HttpWebRequest + CookieContainer就可以让多个web请求只有一个session。
    2009-05-05
  • 用WPF实现屏幕文字提示的实现方法

    用WPF实现屏幕文字提示的实现方法

    本文介绍WPF应用程序实现在屏幕上显示一行或多行文字通知。它没有标题栏和最大化最小化等按钮,可以有半透明背景以使文字的显示更清晰,鼠标点击后提示消失。
    2013-07-07
  • gridview checkbox从服务器端和客户端两个方面实现全选和反选

    gridview checkbox从服务器端和客户端两个方面实现全选和反选

    GridView中的checkbox的全选和反选在很多的地方都是要求实现的,所以下面就从服务器端和客户端两个方面实现了checkbox的选择,感兴趣的朋友可以了解下,希望本文对你有所帮助
    2013-01-01
  • ASP.NET Forms身份认证详解

    ASP.NET Forms身份认证详解

    在这篇文章中,不会涉及ASP.NET的登录系列控件以及membership的相关话题,我只想用比较原始的方式来说明在ASP.NET中是如何实现身份认证的过程。
    2015-09-09
  • 去除HTML标签删除HTML示例代码

    去除HTML标签删除HTML示例代码

    这篇文章主要介绍了如何去除HTML标签、删除HTML。示例中使用到了一个正则,直接使用就可以了
    2014-06-06
  • 深入浅析.NET应用程序SQL注入

    深入浅析.NET应用程序SQL注入

    这篇文章主要介绍了.NET应用程序SQL注入的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • 浅谈Asp.net Mvc之Action如何传多个参数的方法

    浅谈Asp.net Mvc之Action如何传多个参数的方法

    本篇文章主要介绍了Asp.net Mvc之Action如何传多个参数的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-08-08

最新评论