如何在Razor中获得AppUser的角色?

时间:2017-03-16 14:52:39

标签: asp.net-identity asp.net-core-mvc

对于我的用户列表视图,我发送一个AppUser列表:IdentityUser,如下所示:

    public AccountAdminController(UserManager<AppUser> userManager,
        RoleManager<IdentityRole> rolesManager)
    {
        _userManager = userManager;
        _roleManager = rolesManager;
    }

    // List Users
    public ViewResult Index()
    {
        return View(_userManager.Users);
    } 

我在视图中渲染用户:

@model IEnumerable<AppUser>

foreach (AppUser user in Model)
{
    <tr>
        <td>@user.Id</td>
        <td>@user.UserName</td>
        <td>Role</td>
        <td>@user.Email</td>
        <td>
            <a id="editModal" data-toggle="modal" data-target="#modal_box"
                               class="btn btn-sm btn-primary"
                               asp-action="EditUser" asp-route-id="@user.Id">Edit</a>
            <a id="deleteConfirmModal" data-toggle="modal" data-target="#modal_box"
                               class="btn btn-sm btn-danger"
                               asp-action="DeleteConfirm" asp-route-id="@user.Id">Delete</a>
       </td>
   </tr>
}

如何在角色列中获得每个用户的角色?

每个用户的角色集合为空,计数为0,即使我知道用户有角色也是如此。每个用户只有一个角色所以我需要拉@ user.Roles.FirstOrDefault()。姓名。

但它不存在。 我怎么能绕过这个?

更新1

如果我使用include执行此操作:

    public ViewResult Index()
    {
        return View(_userManager.Users.Include(u => u.Roles));
    } 

然后在视图中:

<td>@user.Roles</td>

它呈现:

System.Collections.Generic.List`1[Microsoft.AspNetCore.Identity.EntityFrameworkCore.IdentityUserRole`1[System.String]]

现在,如果我尝试扩展剃刀线:

@user.Roles.FirstOrDefault().

我在intellisense中唯一得到的是RoleId,没有角色名称。

2 个答案:

答案 0 :(得分:1)

你可以这样做。 Haven未对代码进行测试,因此可能需要进行一些返工,但应该让您朝着正确的方向前进。

在您的视图模型中

public class UserViewModel
{
    public ApplicationUser User { get; set; }
    public List<Role> Roles { get; set; }
}

在您的控制器

var usersViewModel = new List<UserViewModel>();
var roles = db.Roles.ToList();
foreach (var user in db.Users)
{
    usersViewModel.Add(new UserViewModel
    {
        User = user,
        Roles = roles.Where(m => m.Users.Any(x => x.UserId == User.Id).ToList();
    });
}
return View(usersViewModel);

答案 1 :(得分:0)

    **try This**
@if (Request.IsAuthenticated)
{
var db = new ApplicationDbContext();
var UserID = User.Identity.GetUserId();
var CurrentUser = db.Users.Where(a => a.Id == UserID).SingleOrDefault();
var roleId = CurrentUser.Roles.FirstOrDefault().RoleId.ToString();
var roleName = db.Roles.Find(roleId).Name.ToString();
}