检查用户是否在asp.net mvc Identity中担任角色

时间:2015-03-17 09:24:54

标签: c# asp.net-mvc asp.net-mvc-4 asp.net-identity

我在使用用户和角色为数据库播种时遇到了问题。

创建了用户和角色(我可以在抛出错误后在数据库中看到它们)。

但是,当我尝试检查用户是否在角色中时,我得到一个例外。

我的代码是:

    public class tbInitializer<T> : DropCreateDatabaseAlways<tbContext>
    {
    protected override void Seed(tbContext context)
    {
        ApplicationDbContext userscontext = new ApplicationDbContext();
        var userStore = new UserStore<ApplicationUser>(userscontext);
        var userManager = new UserManager<ApplicationUser>(userStore);

        var roleStore = new RoleStore<IdentityRole>(userscontext);
        var roleManager = new RoleManager<IdentityRole>(roleStore);


        if(!userscontext.Users.Any(x=> x.UserName=="marktest"))
        {
            var user = new ApplicationUser { UserName = "marktest", Email = "marktest@gmail.com" };
            userManager.Create(user, "Pa$$W0rD!");
        }

        if (!roleManager.RoleExists("Admin"))
        { 
            roleManager.Create(new IdentityRole("Admin"));
        }

        if(!userManager.IsInRole("marktest","Admin"))
        { 
            userManager.AddToRole("marktest","Admin");
        }

然而,在线:

if(!userManager.IsInRole("marktest","Admin"))

引发错误:UserId not found.

在抛出异常后检查时,用户和角色都在数据库中:

Shows User Added to DB

Shows Role Added to DB

任何人都可以看到我做错了吗?

感谢您的帮助,

标记

3 个答案:

答案 0 :(得分:26)

我找到了解决方案,以防其他人遇到此问题。

“IsInRole”期待User.Id - 而不是UserName字符串 - 所以我改为:

            if (!userManager.IsInRole(user.Id, "Admin"))
            {
                userManager.AddToRole(user.Id, "Admin");
            }

因此工作代码变为:

    ApplicationDbContext userscontext = new ApplicationDbContext();
    var userStore = new UserStore<ApplicationUser>(userscontext);
    var userManager = new UserManager<ApplicationUser>(userStore);

    var roleStore = new RoleStore<IdentityRole>(userscontext);
    var roleManager = new RoleManager<IdentityRole>(roleStore);

    // Create Role
    if (!roleManager.RoleExists("Admin"))
    { 
        roleManager.Create(new IdentityRole("Admin"));
    }

    if(!userscontext.Users.Any(x=> x.UserName=="marktest"))
    {
        // Create User
        var user = new ApplicationUser { UserName = "marktest", Email = "marktest@gmail.com" };
        userManager.Create(user, "Pa$$W0rD!");

        // Add User To Role
        if (!userManager.IsInRole(user.Id, "Admin"))
            {
                userManager.AddToRole(user.Id, "Admin");
            }


    }

我希望有所帮助,

标记

答案 1 :(得分:5)

生活中最简单的事情;

bool isAdmin= User.IsInRole("admin") 

答案 2 :(得分:0)

要添加到上述Mark的帖子中,其在.NET Core 3.1中的身份几乎与异步方法IsInRoleAsync唯一相同,您必须传递IdentityUser类型对象:

var userInRole = await _userManager.IsInRoleAsync(user, role);

然后,您可以在以后应用您的逻辑(在我的情况下,我正在做两件事,首先检查角色实际存在,然后检查用户是否尚未分配给该角色)。