MVC 4 SimpleMembership - ¿Por qué WebSecurity.CurrentUserId -1 después de iniciar sesión?

Estoy intentando establecer una cookie al iniciar sesión y tengo problemas para obtener la identificación de usuario actual después de iniciar sesión. En el siguiente, intUserId es -1 y WebSecurity.IsAuthenticated es falso. ¿No es este el lugar correcto para poner este código? Después de esto, redirige a la página de inicio ... así que no estoy seguro de por qué este no es el lugar correcto.

// 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);
        }

Respuestas a la pregunta(1)

Su respuesta a la pregunta