ASP.NET Request.Form 潜在危险检测与修复_ASP.NET 请求验证安全指南
扫描二维码随身看资讯
使用手机 二维码应用 扫描右侧二维码,您可以
1. 在手机上细细品读~
2. 分享给您的微信好友或朋友圈~
在提交表单时候,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配置文件
总结:validateRequest 这句我们知道是关闭验证,也就是说提交带标签,比如 粗体 这样的值时,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属性值
4.0 中多了一个 requestValidationMode,这是什么意思呢?
requestValidationMode 有两个值:
•2.0仅对网页启用请求验证。是启用还是关闭取决于 validateRequest。
•4.0 默认值。任何 HTTP 请求都会启用请求验证,也就是说不光是网页,还包括 Cookie 等。此时强制启用,不管 validateRequest 为何值。
由于 requestValidationMode=4.0 是强制启用,所以我们会发现在 .NET Framework 4.0 中仅靠设置 validateRequest 是关闭不了请求验证的,还得将 requestValidationMode 设置为 2.0。
- 1 aspx安全漏洞防御_禁止跨站读取IIS信息cmd命令执行
- 2 Android设备检测
- 3 ASP.NET 服务器应用程序不可用解决方法_IIS 注册问题排查
- 4 Win8 RP8000 .NET Framework 3.5 安装指南_安装方法
- 5 PHP中session使用方法详解_PHP Session详解
- 6 报错400 Bad Request处理技巧_VS.NET 2003 Web项目问题解决方案
- 7 _NET 2.0 和 4.0 条件编译差异
- 8 ASP.NET AJAX配置简述_AJAX配置指南
- 9 ASP文件定义_ASP文件解释
- 10 ASP.NET 面试题合集_面试题及解析


