【发布时间】:2019-03-12 05:03:42
【问题描述】:
如何列出已分配给某个角色的所有用户。这是我的模型。
namespace Comtrex_ICU.Models
{
public class UsersContext : DbContext
{
public UsersContext()
: base("DefaultConnection")
{
}
public DbSet<UserProfile> UserProfiles { get; set; }
public DbSet<Membership> Membership { get; set; }
public DbSet<Role> Roles { get; set; }
}
[Table("UserProfile")]
public class UserProfile
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int UserId { get; set; }
public string UserName { get; set; }
public string Email { get; set; }
}
[Table("webpages_Roles")]
public class Role
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int RoleId { get; set; }
public string RoleName { get; set; }
}
到目前为止,这是我的控制器:当我单击角色时,它会返回一个视图,其中包含该视图中角色的正确名称:
//List all users for a role
[HttpGet]
public ActionResult List(string UserName, string RoleName)
{
using (UsersContext db = new UsersContext())
{
var roleSelect = db.Roles.Where(r => r.RoleName.Equals(RoleName)).FirstOrDefault();
return View(roleSelect);
}
}
此视图显示所有已保存角色的列表,其中包含用于编辑、删除和列出该特定角色的链接。
@{
ViewBag.Title = "RoleIndex";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<div class="spacerBody">
<h2 class="admin-home-link">@Html.ActionLink("Roles", "AdminIndex")</h2>
@Html.ActionLink("Create New Role", "RoleCreate") |
@Html.ActionLink("Manage User Roles", "RoleAddToUser")
<p> </p>
<div>
@foreach (string s in Model)
{
<div id="userRolesList">
<p class="role-p">
@s
|<span onclick="return confirm('Are you sure to delete?')">
<a href="/Account/RoleDelete?RoleName=@s"
class="delLink"> <span style="color: #f05322">Delete</span>
</a>
</span>
|<a href="/Account/Edit?RoleName=@s">Edit</a>
|<a href="/Account/List?RoleName=@s">List</a>
</p>
</div>
<div>
</div>
}
</div>
</div>
然后,当我单击列表链接时,它会将我带到此视图:
@model Comtrex_ICU.Models.Role
@{
ViewBag.Title = "List";
Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2 class="admin-home-link">@Html.ActionLink("List", "AdminIndex")</h2>
<hr/>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
@Html.ValidationSummary(true)
@Html.HiddenFor(m => m.RoleId)
<p>
@Model.RoleName
</p>
}
我将如何列出与正确角色相对应的特定用户?
【问题讨论】:
-
我认为这就是
Membership的用途,尽管您没有展示该模型。如果是这样,您将使用您的角色条件对其进行查询,加入以获取详细信息并返回结果。
标签: c# asp.net-mvc model-view-controller