在 ASP.NET MVC 中禁用请求验证

来源:未知 责任编辑:责任编辑 发表时间:2013-11-18 20:56 点击:

默认情况下,ASP.NET MVC 框架禁止用户提交带有潜在危险性的内容,例如,如果在文本输入框中输入HTML内容,则会报告类似如下的错误:

从客户端(TextBox1="<a></a>")中检测到有潜在危险的 Request.Form 值。 

这个功能可以减少脚本攻击的可能性,但有时候,又需要允许客户输入HTML内容,如发布文章,又必须禁止请求的验证功能,这个时候,在页面中写:

ASPX 代码
<%@ Page ValidateRequest=”false” %>
这个指令就无效了,也不能在web.config里进行设置,在 MVC 中,如果要禁用请求验证,就需要 [ValidateInput] 属性。比如:

C# 代码
[ValidateInput(false)]  
[AcceptVerbs(HttpVerbs.Post)]  
public ActionResult Create([Bind(Exclude="Id")]Product productToCreate)  
{  
    if (!ModelState.IsValid)  
        return View();  

    _dataModel.AddToProductSet(productToCreate);  
    _dataModel.SaveChanges(); 
    return RedirectToAction("Index");
}
 

 

作者:孟宪会
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • 浅析.NET下XML数据访问新机制
    • asp.net 面试+笔试题目第1/2页
    • C# 邮件地址是否合法的验证
    • asp.net 设置GridView的选中行的实现代码
    • C#高级编程:数据库连接[1]
    • 经典C++程序1
    • IIS 自动回收导致后台定时器失效的问题解决
    • ASP.NET&#160;GridView列表代码示例
    • Asp.net MVC源码分析--Action Filter的链式调用
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1