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中“从客户端中检测到有潜在危险的Request.Form值”错误的解决办法
-
ASP.NET MVC(Razor)从客户端中检测到有潜在危险的 Request.Form 值
-
从客户端(body=\“...stions? We';re here to help...\“)中检测到有潜在危险的 Request.Form 值
-
解决asp.net中“从客户端中检测到有潜在危险的Request.Form值”的错误
-
解决asp.net中“从客户端中检测到有潜在危险的Request.Form值”的错误
-
从客户端中检测到有潜在危险的Request.Form值
-
"从客户端中检测到有潜在危险的 Request.Form 值。"
-
解决从客户端中检测到有潜在危险的Request.Form值
-
从客户端(XXX)中检测到有潜在危险的 Request.Form 值
-
从..中检测到有潜在危险的 Request.Form 值。