ValidateInput属性似乎不适用于ASP.NET MVC

时间:2009-09-22 17:06:28

标签: asp.net asp.net-mvc

我正试图绕过“潜在危险的Request.Form值”错误,我没有运气。是的,是的,我已经阅读了所有其他与StackOverflow相关的问题,但似乎没有一个问题让我更接近答案。我在所有相关的控制器操作上使用[ValidateInput(false)] ...我已经多次检查过了。我在所有相关的ASPX视图中使用ValidateRequest='false'

我正在使用ASP.NET MVC 2 Preview 1,但我不认为这是一个问题,因为错误是在框架中生成的; Page.ProcessRequest确切。我看不到任何我做错的事情,我甚至在web.config中设置<page validateRequest='false'>并且也没有解决它。

4 个答案:

答案 0 :(得分:32)

使用asp.net 4,您还需要在web.config中配置验证模式。

将以下内容设置为<system.web>元素的子元素:

<httpRuntime requestValidationMode="2.0"/>

Asp.Net 4默认将requestValidationMode设置为4.0,告诉系统在HTTP请求的BeginRequst阶段之前执行请求验证。验证将在系统到达action属性之前发生,告诉它不验证请求,从而使属性无效。设置requestValidationMode =“2.0”将恢复为asp.net 2.0请求验证行为,允许ValidateInput属性按预期工作。

(感谢吉姆 - upvotes belong here

答案 1 :(得分:7)

嗯......回答了我自己的问题......罪魁祸首:Html.RenderAction<T>。如果在请求上下文中有任何其他操作的调用(例如,来自母版页或子部分),则这些操作还需要适当地设置[ValidateInput(false)]。这似乎是一个问题,虽然使用MVC或Page对象在ASP.NET中的工作方式,因为这是一个真正混淆的bug。

答案 2 :(得分:1)

您必须将该属性添加到请求期间调用的每个控制器操作,即检查所有部分请求。

答案 3 :(得分:0)

请注意,这些建议无法解决因必须将[ValidateInput(false)]与FormCollection结合使用而导致的错误所导致的问题。

请参阅:ASP.NET MVC 3 ValidateRequest(false) not working with FormCollection