@using (Ajax.BeginForm("Login", "Account", "",
new AjaxOptions { HttpMethod = "POST" },
new { id = "loginForm", name = "loginForm" }))
{
...
}
此表单执行请求并收到响应 200 OK。调试我可以看到响应 html,但我没有被重定向。
如果我在不使用 html 的情况下手动执行此操作,则可以帮助我成功重定向到我需要的位置。
这是控制器:
//
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model)
{
MembershipProvider mp = Membership.Provider;
bool isDigital = bool.Parse(Request.Form.GetValues("hasDigital")[0]);
string certDBNumber;
if (isDigital)
{
/*** Retira só o que enteressa do Certificado.Subject (CPF/CNPJ)*/
string code = Request.Form.GetValues("code")[0];
string[] dataArray = code.Split(',');
string data = dataArray.Last();
string[] numberArr = data.Split(':');
string number = numberArr.Last();
/*** Resgata chave do usuário no banco ***/
using (tgpwebgedEntities context = new tgpwebgedEntities())
{
var userObj = from u in context.aspnet_Users
where u.UserName == model.UserName
select u.UserId;
Guid userID = userObj.First();
var obj = from u in context.sistema_UsersCertified
where u.userID == userID select u.keyNumber;
certDBNumber = obj.First();
}
//Verifica se usuário é credenciado
if (number == certDBNumber) {
FormsAuthentication.SetAuthCookie(model.UserName, false);
return RedirectToAction("Index", "Home");
}
}//Login sem certificado digital
else
{
if (ModelState.IsValid &&
mp.ValidateUser(model.UserName, model.Password))
{
FormsAuthentication.SetAuthCookie(model.UserName, false);
return RedirectToAction("Index", "Home");
}
}
/*** Se chegou até aqui algo deu errado. Mostra denovo o form ***/
ModelState.AddModelError("", "Username ou Password incorreto!.");
return View(model);
}
为什么会有这种奇怪的行为?