作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我们在同一个 cshtml 页面上有多个可能的表单要发布到 Controller 时,防伪验证不起作用。我们检查了 MVC3 代码,发现问题出在这部分代码中:
if (!String.Equals(cookieToken.Value, formToken.Value, StringComparison.Ordinal)) {
// error: form token does not match cookie token
throw CreateValidationException();
}
我们拥有的 cshtml 是这样的:
@using (@Ajax.BeginForm()) {
@Html.AntiForgeryToken()
<input type="submit" class="buttonBlue" value="form1" />
}
@using (@Ajax.BeginForm()) {
@Html.AntiForgeryToken()
<input type="submit" class="buttonBlue" value="form2" />
}
你能帮我解决这个问题吗?我们发现在删除其中一个防伪标记后,一切似乎都按预期工作。
我们尝试设置防伪的机器 key ,但也没有用。
问候。
最佳答案
为了多次使用 AntiForgeryToken,我执行以下操作。首先,在我的 View 顶部,我添加以下行:
ViewBag.__RequestVerificationToken = @Html.AntiForgeryToken().ToString();
然后,在我需要 token 的每个表单中,我添加以下内容:
@Html.Raw(ViewBag.__RequestVerificationToken)
关于ajax - 如何在同一个 MVC3 页面上使用多个带有 AntiForgery 验证的 ajax 表单?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8271085/
我是一名优秀的程序员,十分优秀!