MVC 5:Asp.net 身份:如何对用户角色进行建模



我是MVC 5 asp.net 身份模型的新手,正在寻找自定义标准 Asp.net 身份的方法以满足我的需求。通过关于TypeCast Exception的博客和Stackoverflow:如何建模身份的博客,我能够在ApplicationUser和ApplicationRole表中创建自己的元素。但是,我的要求是向UserRole表添加新列,DATE_FROM和DATE_TO我通过实现IdentityUserRole接口做到了这一点。我的问题是当我尝试保存链接UserManager.AddRoleToUser时,它只接受两个参数,UserName和RoleName。如何存储自定义ApplicationUserRole的参数?

public bool AddUserToRole(string userId, SelectUserRolesViewModel roleName)
{
                var um = new UserManager<ApplicationUser>(
                    new UserStore<ApplicationUser>(new ApplicationDbContext()));

                var idResult = um.AddToRole(userId, roleName);
                return idResult.Succeeded;
            }

SelectUserRolesViewModel 提供扩展的 IdnetityUserRole 模型。任何指针都将不胜感激。

如果向 ApplicationUserRole 表添加其他属性,则不能再使用AddUserToRole方法。由于AddUserToRole方法来自密封类UserManagerExtensions类,因此您无法创建自己的类来继承UserManagerExtensions。我不确定是否有更好的解决方案,但下面是一个工作示例。

ApplicationUserRole表添加其他属性:

public class ApplicationUserRole : IdentityUserRole
{
    public DateTime DateFrom { get; set; }
    public DateTime DateTo { get; set; }
}
public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
    public ApplicationDbContext()
        : base("DefaultConnection")
    {
    }
    public DbSet<ApplicationUserRole> ApplicationUserRoles { get; set; }
}

然后,您可以创建一个新的ApplicationUserRole实例,如下所示:

    using (var _db = new ApplicationDbContext())
    {
        var roleName = //Get role name from somewhere here
        var roleManager = new RoleManager<IdentityRole>(new RoleStore<IdentityRole>(_db));
        if (!roleManager.RoleExists(roleName))
        {
             var newRoleresult = roleManager.Create(new IdentityRole()
             {
                  Name = roleName,
             });
        }
        var userRole = new ApplicationUserRole
        {
            UserId = currentUser.Id,
            RoleId = roleManager.FindByName(roleName).Id,
            DateFrom = DateTime.Now,
            DateTo = DateTime.Now.AddDays(1)
        };
        _db.ApplicationUserRoles.Add(userRole);
        _db.SaveChanges();
   }

最新更新