【发布时间】:2010-11-10 19:37:01
【问题描述】:
在 asp.net/mvc 身份验证的经典示例中,LogOn 操作获取 LogOnViewModel 和 returnUrl 字符串以进行身份验证并重定向到以前的 Url。
[HttpPost]
public ActionResult LogOn(LogOnViewModel model, string returnUrl)
{
if (ModelState.IsValid)
if (!FormsAuthentication.Authenticate(model.UserName, model.Password))
ModelState.AddModelError("", "Incorrect user name or password.");
if (ModelState.IsValid)
{
FormsAuthentication.SetAuthCookie(model.UserName, false);
return Redirect(returnUrl ?? "Bookings");
}
else
return View();
}
但是当请求由动作处理时,returnUrl 参数为空,但是应该有一个值,正如作者所说。有人可以解释一下吗?
我发送请求的表单如下所示:Views/Admin/LogOn.aspx
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<div id="login">
<% Html.EnableClientValidation(); %>
<% using (Html.BeginForm("LogOn", "Admin")) { %>
<%= Html.ValidationSummary(true) %>
<div><label>Username:</label><input name="userName" type="text" /></div>
<div><label>Password:</label><input name="password" type="password" /></div>
<div><input type="submit" value="Login" /></div>
<% } %>
</div>
</asp:Content>
表单上没有生成隐藏字段。
身份验证:
<authentication mode="Forms">
<forms loginUrl="~/Admin/LogOn" timeout="2880">
<credentials passwordFormat="SHA1">
<user name="admin" password="hashedPassword"/>
</credentials>
</forms>
</authentication>
【问题讨论】:
-
您的提交表单是什么样的?如果您使用
POST请求提交,您是否有returnUrl参数的隐藏元素?