现在开始表单,第一次,当我开始调试 MVC 应用程序时,我收到此错误
视图状态 MAC 验证失败。如果
该应用程序由 Web 托管
农场或集群,确保
配置指定
相同的validationKey和validation
算法。无法使用自动生成
在一个集群中。
完整的堆栈跟踪
[ViewStateException: Invalid viewstate.
Client IP: 127.0.0.1
Port:
Referer:
Path: /Login/LogOn
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US) AppleWebKit/534.7 (KHTML, like Gecko) Chrome/7.0.517.41 Safari/534.7
ViewState: Fvq7WNUu+qCC00VbTIOTUuBvK4YHjxp3RubwsrFYW93hKlF7I4GLzaNHceRqjjJB0GwvRPWwlwE6brhAZAo+Mp191B/C+l8Dw/w7aQBDCpWGC3ox6hkSeZp10vbjm9eJFQZmGSPyC1rKYwApBBaz0Q==]
[HttpException (0x80004005): Validation of viewstate MAC failed. If this application is hosted by a Web Farm or cluster, ensure that <machineKey> configuration specifies the same validationKey and validation algorithm. AutoGenerate cannot be used in a cluster.]
System.Web.UI.ViewStateException.ThrowError(Exception inner, String persistedState, String errorPageMessage, Boolean macValidationError) +198
System.Web.UI.ViewStateException.ThrowMacValidationError(Exception inner, String persistedState) +14
System.Web.UI.ObjectStateFormatter.Deserialize(String inputString) +274
System.Web.UI.ObjectStateFormatter.System.Web.UI.IStateFormatter.Deserialize(String serializedState) +4
System.Web.Mvc.AntiForgeryDataSerializer.Deserialize(String serializedToken) +176
这意味着什么?
请注意:该错误仅在调试期间发生。当我在本地 IIS 上部署应用程序时,一切正常。它出现在我的母版页中的以下代码中
<form id="__AjaxAntiForgeryForm" action="#" method="post">
<%= Html.AntiForgeryToken() %>
</form>
发生这种情况的直接原因是防伪 cookie 失效。关闭并重新打开浏览器应该可以解决该问题。您也可以尝试删除与您的测试站点关联的 cookie。
现在就根本原因而言,这种情况通常会发生,因为
- 您处于网络场场景中,并且您的各种服务器的配置方式不同(但您说情况并非如此)
- 由于您对应用程序配置所做的更改,应用程序会更改自动生成的 MAC
- 您最近应用了一个补丁来修复 Asp.Net ViewState 加密漏洞(该漏洞改变了 asp.net 中执行加密的方式)。
这些听起来很熟悉吗?
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)