[英]Adding user info to session data right when user logins
我目前有以下登录脚本:
[HttpPost]
public ActionResult LogOn(LogOnModel model)
{
if (ModelState.IsValid)
{
if (Membership.ValidateUser(model.UserName, model.Password))
{
FormsAuthentication.SetAuthCookie(model.UserName, model.RememberMe);
Guid MyUserId = (Guid)Membership.GetUser().ProviderUserKey;
System.Web.HttpContext.Current.Session[MyUserId.ToString()] = profileRepository.GetFullProfile(MyUserId);
return Json(true);
}
else
{
return Json("The user name or password provided is incorrect.");
}
}else
return Json("The user name or password provided is incorrect.");
}
我在Membership.GetUser()
上收到一个错误,说该object reference
错误。 我对此进行了研究,发现这是因为只有下一个http请求将通过身份验证,所以在用户登录时将用户数据保存到会话中的最佳方法是什么? 是否可以确保一直存在到会话中,直到用户的会话到期并将其踢出去,还是会出现用户没有会话数据集登录的实例? 如果有病,也需要一些东西来处理。
我在asp.net application
(不是MVC)中的LoginButton_Clicked
中发生了这种情况。 甚至以为成功登录后会触发此事件( LoginButton_Clicked
)Membership.GetUser(),Roles.GetRolesForUser(),Profile尚未填写。因此,需要将用户名传递给每个方法以获取详细信息。
我认为MVC中也发生了同样的事情。
您可以通过传递model.UserName来获取用户详细信息,如下所示。
MembershipUser mu = Membership.GetUser(model.UserName);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.