我正在逐步将我的项目从 asp.net Web 表单升级到 MVC4。在第一步中,我更改了登录页面和其他几个页面。我正在使用表单身份验证,具有我自己的逻辑(无成员资格) - 我根据数据库表检查用户名/密码。如果没问题,用户将被重定向到其目的地。我的登录代码是:
网络配置:
<authentication mode="Forms">
<forms loginUrl="~/LogIn" name=".ASPXFORMSAUTH" timeout="150" />
</authentication>
<authorization>
<deny users="?" />
</authorization>
登录控制器:
[AllowAnonymous]
[HttpPost]
public ActionResult AjaxLogin(FormCollection postedFormData)
{
try
{
string userName = postedFormData["Login_UserName"];
string password = postedFormData["Login_Password"];
UserEntity userEntity = new UserEntity(Utilities.AuthenticateUser(userName, password, 1));
Session["UserEntity"] = userEntity;
FormsAuthentication.SetAuthCookie(userEntity.Key.Id.ToString(), false);
return Json(new { redirectToUrl = "./AccountSelection", error = "false", lan = Thread.CurrentThread.CurrentUICulture.ToString() });
}
catch (Exception ex)
{
return Json(new { redirectToUrl = "", error = ExceptionHandler.HandleException(ex), lan = Thread.CurrentThread.CurrentUICulture.ToString() });
}
}
当我尝试登录时,我得到 http 302 并重定向回登录。如果我删除 web.config 上的“授权”部分,它会正常工作,但现在我有两个问题:
- 我必须在每个控制器上加上 [authorize] 属性
- 我的webforms不会在forms认证里面(不用登录就可以直接访问!!)
我究竟做错了什么?