我有一个基于MVC3的网络应用程序(没有测试版或候选版本,RTM / RTW版本),它有一个接受XML文件进行处理的动作。
当然,由于可能的攻击,这对MVC来说似乎是邪恶的,所以它不允许它。好吧,我尝试将AllowHtml放在模型对象上:
public class XMLModel
{
[AllowHtml]
public string msg { get; set; }
}
或者我在我的操作方法上将ValidateInput设置为false,例如:
[ValidateInput(false)]
public ActionResult AddCDR(XMLModel model)
{
}
首先使用“强”类型模型的原因是我最初尝试将一个名为“msg”的字符串值作为操作方法参数,但总是空回来。
现在,当有人在同一台计算机或联网计算机上发布此表单时,msg字段始终为空白。
我已经使用WireShark验证了数据实际上在请求中。
现在,一件有趣的事情。 对于MVC 3,这不是必需的。但它略有不同。
如果我将其添加到我的网络配置:
<httpRuntime requestValidationMode="2.0" />
它适用于来自本地计算机的请求,但它不适用于其他系统。
我认为AllowHtml版本似乎很优雅 - 只要它有效。
我也发现了RC2中的一个错误 - 再次,这不应该影响我,但我还是尝试在Application_Start()中添加以下内容:
ModelMetadataProviders.Current = new DataAnnotationsModelMetadataProvider();
正如预期的那样,它没有什么不同。
一切都在我的开发计算机(Win7x64,VS2010)上按预期工作,但在目标系统(Win2008R2x64,IIS7.5)上,上述问题让我很难过。
非常重要的一点要注意:如果我发布没有尖括号的动作,我会按预期获得表单数据。但是,一旦尖括号出现,我的动作根本就没有被调用,或者它没有找到表单数据,也没有在动作方法参数中或在例如Request.Params [“msg”]中找到它应该。
任何允许XML通过的想法?
UPDATE
在等待有人在这里提出答案时,我试图绕过这个问题。我还没有解决它,但我已经检查了一些额外的细节;
- 首先,我验证了我的开发计算机和Web服务器上安装的ASP.NET MVC 3版本是相同的; v3.0.20105.0(根据添加/删除程序)。
- Web应用程序实际上是使用MVC3 beta创建的,然后在它们出现时转换为RC1和RC2,最后转换为RTM版本。这意味着我必须修改一些代码,因为ViewBag更改。但是,由于我不确切知道其他更改,我使用RTM版本创建了一个全新的MVC3应用程序,使用相同的操作方法创建了一个相同名称的控制器,获取了与当前使用的模型对象类似的模型对象,重命名旧的Web应用程序目录并将新的目录放在适当的位置。完全相同的事情发生 - 即当从本地机器发出请求时,具有AllowHtml属性的参数通过所有内容,但如果它来自远程机器,则HTML(实际上是XML)被剥离。
- 没有例外。我已经安装了Elmah并验证了这一点 - 没有异常发生,我的动作方法显然只是调用了从参数到方法的XML被剥离的东西。
不用说,这让我发疯了。昨天我有一些建议来查看MVC3的源代码,但不幸的是,这并没有真正帮助我,因为我看不到任何明显的错误,我无法在有问题的服务器上调试代码。
任何见解仍然非常需要,谢谢! :)