1

我在 MVC 3 (razor) 应用程序中使用 .net 成员资格。

我已经实现了一个自定义配置文件类,我在其中使用 HttpContext.Current.User.Identity.Name 来获取会员用户。

public class UserProfile : ProfileBase
{
    static public UserProfile CurrentUser
    {
        get {
               return (UserProfile)(ProfileBase.Create(Membership.GetUser(new Guid(HttpContext.Current.User.Identity.Name)).UserName)); 
            }
    }

    public string FirstName
    {
        get { return ((string)(base["FirstName"])); }
        set { base["FirstName"] = value; Save(); }
    }

    public string LastName
    {
        get { return ((string)(base["LastName"])); }
        set { base["LastName"] = value; Save(); }
    }
}

正如您在上面的课程中看到的那样,我必须将 HttpContext.Current.User.Identity.Name 转换为 GUID 才能获得会员用户。

问题是,为什么在登录验证之后,在 HttpContext.Current.User.Identity.Name 我得到的是 GUID 值(userID)而不是用户名?

这正常吗?

4

2 回答 2

0

如果您使用默认的 .NET 成员资格(FormAuthentication with default GenericPrincipal, FormsIdentity)并且您已经从默认的“Internet 应用程序”模板创建了 MVC 应用程序,那么:

检查 AccountController 的“LogOn”操作方法。将 userName 更改为 UserId(GUID) 值的一种可能原因是将 Auth-cookie 设置为 'ProviderUserKey' 作为 userName,例如:

[HttpPost]
public ActionResult LogOn(LogOnModel model, string returnUrl)
{
    if (ModelState.IsValid)
    {
        if (Membership.ValidateUser(model.UserName, model.Password))
        {
            var user = Membership.GetUser(model.UserName);
            FormsAuthentication.SetAuthCookie(user.ProviderUserKey.ToString(), model.RememberMe);

            //...
            return Redirect(Url.Content("~/"));
        }
        else{
            ModelState.AddModelError("", "The user name or password provided is incorrect.");
        }
    }

    // If we got this far, something failed, redisplay form
    return View(model);
}
于 2012-04-24T16:19:31.893 回答
0

只需使用 Membership.GetUser() 来获取当前用户。

于 2012-04-24T13:24:09.120 回答