How to add a simple user roles - ASP.NET MVC C#

后端 未结 1 861
醉酒成梦
醉酒成梦 2021-01-30 11:54

I\'m pretty new to ASP.NET MVC, and I\'ve been looking at a lot of different ways of adding User Roles for my ASP.NET MVC site. I want to use the users\' database(s) that are au

相关标签:
1条回答
  • 2021-01-30 12:15

    The first step is to create the admin role. This is easy enough:

    context.Roles.Add(new IdentityRole { Name = "admin" });
    context.SaveChanges();
    

    To add the role to an existing user:

    var role = context.Roles.SingleOrDefault(m => m.Name == "admin");
    user.Roles.Add(new IdentityUserRole { RoleId = role.Id });
    

    Both of these steps can and should be handled in your Seed method of Migrations\Configuration.cs, along with creating any initial users that should be administrators.

    For the ability of administrators to add roles to other users, you've got the first step covered already: protect the action with [Authorize(Roles = "admin")].

    Next, you'll need a view model to work with your user. Something like the following:

    public class UserViewModel
    {
        // User properties you'd like to edit goes here
    
        public List<int> SelectedRoleIds { get; set; }
    
        public IEnumerable<SelectListItem> RoleChoices { get; set; }
    }
    

    You'll need to map your ApplicationUser to/from this view model. Then, you'll need to manually populate the two role properties in UserViewModel:

    RoleChoices should be an enumerable of all available roles:

    model.RoleChoices = context.Roles.Select(m => new SelectListItem
    {
        Value = m.Id,
        Text = m.Name
    });
    

    SelectedRoleIds should be a list of the ids of all roles currently assigned to the user:

    model.SelectedRoleIds = user.Roles.Select(m => m.RoleId);
    

    In your view, then, you'll construct your multiselect:

    @Html.ListBoxFor(m => m.SelectedRoleIds, Model.RoleChoices)
    

    When creating a new user, you can simply set the user's roles directly on post:

    user.Roles = model.SelectedRoleIds.Select(m => new IdentityUserRole { RoleId = m });
    

    When editing an existing user, greater care has to be taken, since you'll get integrity errors if you save the same role id twice for the same user. First, you'll need to remove any roles that have been deselected:

    user.Roles.Where(m => !model.SelectedRoleIds.Contains(m.RoleId))
        .ToList().ForEach(role => user.Roles.Remove(role));
    

    Then, you'll need to add any newly selected roles:

    var existingUserRoles = user.Roles.Select(m => m.RoleId);
    model.SelectedRoleIds.Except(existingUserRoles)
        .ToList().ForEach(roleId => user.Roles.Add(new IdentityUserRole
        {
            RoleId = roleId
        }));
    
    0 讨论(0)
提交回复
热议问题