per*_*röm 3 c# asp.net asp.net-mvc user-roles
我试图找出如何让所有用户和他们的角色进入一个很好的组织表,看到许多不同的方式,但没有一个对我有用.我至少在最重要的路上得到了升功...任何可以帮助我的人?
使用此代码,我将获得所有角色:
var context = new ApplicationDbContext();
var roleStore = new RoleStore<IdentityRole>(context);
var roleManager = new RoleManager<IdentityRole>(roleStore);
var roles = (from r in roleManager.Roles select r.Name).ToList();
ViewBag.Roles = roles.ToList();
Run Code Online (Sandbox Code Playgroud)
并使用此代码我得到所有注册用户:
var context = new ApplicationDbContext();
var userStore = new UserStore<ApplicationUser>(context);
var userManager = new UserManager<ApplicationUser>(userStore);
var users = (from u in userManager.Users select u.UserName).ToList();
ViewBag.Users = users.ToList();
Run Code Online (Sandbox Code Playgroud)
最后使用此代码我获得所有用户ID
var context = new ApplicationDbContext();
var user = (from u in userManager.Users select u.Id).ToList();
ViewBag.id = user.ToList();
Run Code Online (Sandbox Code Playgroud)
但是我如何让所有用户获得他们的角色?我真的无法弄明白
这是获取用户列表(使用用户名)和关联角色列表的一个选项.
控制器:
public ActionResult GetRoles()
{
var userRoles = new List<RolesViewModel>();
var context = new ApplicationDbContext();
var userStore = new UserStore<ApplicationUser>(context);
var userManager = new UserManager<ApplicationUser>(userStore);
//Get all the usernames
foreach (var user in userStore.Users)
{
var r = new RolesViewModel
{
UserName = user.UserName
};
userRoles.Add(r);
}
//Get all the Roles for our users
foreach (var user in userRoles)
{
user.RoleNames = userManager.GetRoles(userStore.Users.First(s=>s.UserName==user.UserName).Id);
}
return View(userRoles);
}
Run Code Online (Sandbox Code Playgroud)
视图模型
public class RolesViewModel
{
public IEnumerable<string> RoleNames { get; set; }
public string UserName { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
查看:简单的一个
@model IEnumerable<StackOverflow.Models.RolesViewModel>
@foreach (var user in Model.ToList())
{
<div> @user.UserName -- </div>
foreach (var role in user.RoleNames)
{
<div> @role </div>
}
<br />
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4933 次 |
| 最近记录: |