Asp.net mvc MVC 4 SimpleMembership-登录后为什么选择WebSecurity.CurrentUserId-1
我试图在登录时设置cookie,但在登录后获取当前用户id时遇到问题。在下图中,intUserId为-1,WebSecurity.IsAuthenticated为false。这不是放置此代码的正确位置吗?在此之后,它会重定向到主页…所以不确定为什么这不是正确的位置Asp.net mvc MVC 4 SimpleMembership-登录后为什么选择WebSecurity.CurrentUserId-1,asp.net-mvc,simplemembership,Asp.net Mvc,Simplemembership,我试图在登录时设置cookie,但在登录后获取当前用户id时遇到问题。在下图中,intUserId为-1,WebSecurity.IsAuthenticated为false。这不是放置此代码的正确位置吗?在此之后,它会重定向到主页…所以不确定为什么这不是正确的位置 // POST: /Account/Login [HttpPost] [AllowAnonymous] [ValidateAntiForgeryToken] publi
// POST: /Account/Login
[HttpPost]
[AllowAnonymous]
[ValidateAntiForgeryToken]
public ActionResult Login(LoginModel model, string returnUrl)
{
if (ModelState.IsValid && WebSecurity.Login(model.UserName, model.Password, persistCookie: model.RememberMe))
{
//TODO: set current company and facility based on those this user has access to
int intUserId = WebSecurity.GetUserId(User.Identity.Name);
int intUserId2 = WebSecurity.GetUserId(model.UserName);
UserSessionPreferences.CurrentCompanyId = 1;
UserSessionPreferences.CurrentFacilityId = 1;
return RedirectToLocal(returnUrl);
}
// If we got this far, something failed, redisplay form
ModelState.AddModelError("", "The user name or password provided is incorrect.");
return View(model);
}
登录仅设置表单身份验证cookie asp.net身份验证的工作方式是,它必须读取cookie以设置对请求的身份验证,但由于启动登录页面时cookie不存在,因此框架对用户一无所知 重新加载页面,您将发现信息可用
仅供参考,这对于SimpleMembership或WebSecurity来说并不是什么新鲜事,这是表单身份验证一直以来的工作方式。Ok,所以我使用了int intUserId2=WebSecurity.GetUserId(model.UserName);获取该用户的id。感谢您的帮助。