1
@using (Ajax.BeginForm("Login", "Account", "",
new AjaxOptions { HttpMethod = "POST" },
new { id = "loginForm", name = "loginForm" }))
{
...
}
此表单执行请求并接收响应200 OK。 Debbuging我可以看到响应html,但我没有被重定向。@ Ajax.BeginForm请求/响应正常但控制器没有重定向
如果我这样做,而不使用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);
}
为什么这种奇怪的行为?