如何在使用自定义成员资格/角色提供程序时使用自定义httpcontext用户

时间:2012-09-12 05:19:07

标签: asp.net-mvc membership-provider

大家好,我正在使用自定义成员资格提供程序和自定义角色提供程序。它正在使用这些正确登录。我还实现了自己的Membership用户对象,这样我就可以访问其他用户信息,而且每次更改页面时都不需要加载所有数据,但我目前无法正常工作。下面是我的用户对象:

public class User : MembershipUser
{
    [Required(ErrorMessage = "Username cannot be blank")]
    [Display(Name = "User name")]
    public string UserName { get; set; }

    [Required(ErrorMessage = "Password cannot be blank")]
    [DataType(DataType.Password)]
    [Display(Name = "Password")]
    public string Password { get; set; }

    [Display(Name = "User ID")]
    public long UserID { get; set; }

    [Display(Name = "Family Name")]
    [StringLength(50, ErrorMessage = "Family name cannot be longer than 50 characters")]
    public string FamilyName { get; set; }

    [Display(Name = "Given Name")]
    [StringLength(50, ErrorMessage = "Given name cannot be longer than 50 characters")]
    public string GivenName { get; set; }

    public Company Company { get; set; }

    public virtual IIdentity Identity { get; set; }
}

当用户登录时,我调用以下登录方法:

    [AllowAnonymous]
    [HttpPost]
    public ActionResult Login(User model, string returnUrl)
    {
        FormsAuthentication.SignOut();
        if(Membership.ValidateUser(model.UserName, model.Password))
        {
            FormsAuthentication.SetAuthCookie(model.UserName, true);
            return RedirectToAction("Index", "");
        }
        ViewBag.Message = "Failed to login";
        return View();
    }

但是当我在索引中调用HttpContext.User时,它只包含名称/ ID,而不是我的用户对象的其余部分。我是否需要创建自定义FormAuthentication对象?或者是将所有这些用户信息存储在HttpContext.Session对象中的标准过程?或者让我的用户扩展System.Security.Principle.IPrinciple?甚至在Controller.TempData?或者其他我不熟悉的地方。我不想每次都要点击数据库来加载用户数据。

很抱歉,如果这些是显而易见的问题,我对Web开发还不熟悉,也不确定执行这些操作的一般方法是什么。尝试使用in build Authorize属性。

1 个答案:

答案 0 :(得分:5)

我是通过实现自己的身份来实现的。这样就很容易添加我需要的多个属性。下面是自定义属性friendlyName

的代码示例
public class Identity : IIdentity
    {
        public Identity(int id, string name, string friendlyName, string roles)
        {
            this.ID = id;
            this.Name = name;
            this.FriendlyName = friendlyName;
            this.Roles = roles;
        }



  public Identity(string name, string data)
    {
        if (string.IsNullOrWhiteSpace(data))
            throw new ArgumentException();

        string[] values = data.Split('|');
        if (values.Length != 3)
            throw new ArgumentException();

        this.Name = name;
        this.ID = Convert.ToInt32(values[0]);
        this.FriendlyName = values[1];
        Roles = values[2];
    }

    public string AuthenticationType
    {
        get { return "Custom"; }
    }

    public bool IsAuthenticated
    {
        get { return true; }
    }

    public override string ToString()
    {
        return FriendlyName;
    }

    public string GetUserData()
    {
        return string.Format("{0}|{1}|{2}", ID, FriendlyName, Roles);
    }


    public int ID { get; private set; }
    public string Name { get; private set; }
    public string FriendlyName { get; private set; }
    public string Roles { get; private set; }
}

//in controller on login action:
        Identity id = new Identity(user.ID,  user.Username, "some friendly name", user.Roles);
        DateTime expire = DateTime.Now.AddMinutes(FormsAuthentication.Timeout.TotalMinutes);
        FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(id.ID, user.Username, DateTime.Now, expire, false, id.GetUserData());
        string hashTicket = FormsAuthentication.Encrypt(ticket);
        HttpCookie cookie = new HttpCookie(FormsAuthentication.FormsCookieName, hashTicket);
        HttpContext.Response.Cookies.Add(cookie);

在global.asax中你有:

public override void Init()
        {
            base.Init();
            PostAuthenticateRequest += new EventHandler(MvcApplication_PostAuthenticateRequest);
        }

    void MvcApplication_PostAuthenticateRequest(object sender, EventArgs e)
    {
        HttpCookie authCookie = Request.Cookies[FormsAuthentication.FormsCookieName];
        if (authCookie != null)
        {
            FormsAuthenticationTicket authTicket = FormsAuthentication.Decrypt(authCookie.Value);
            if (authTicket == null || authTicket.Expired)
                return;

            Identity id = new Identity(authTicket.Name, authTicket.UserData);
            Principal user = new Principal(id);
            Context.User = user;
            Thread.CurrentPrincipal = user;
        }
    }