В классическом примере аутентификации 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 имеет значениеnull, однако должно быть значение, как говорит автор.Может ли кто-нибудь объяснить это?
Форма, из которой я отправляю запрос, выглядит следующим образом: 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>