对于我的用户列表视图,我发送一个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()。姓名。
但它不存在。 我怎么能绕过这个?
如果我使用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,没有角色名称。
答案 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();
}