0

我的行动

[Authorize(Roles = "Admin")]
public ActionResult Index()
{
    using (var ctx = new _dbContext())
    {
        return View(ctx.UserProfiles.OrderBy(x => x.UserId).ToList());
    }
}

我想用 UserId 和 UserName 显示角色,我该怎么做?

更新:查看模型

public class AccountIndexViewModel
{
    public int UserId { get; set; }
    public string UserName { get; set; }
    public string Roles { get; set; }
}

看法

@using GoldCalculator.Models
@model IEnumerable<AccountIndexViewModel>
            @foreach (var user in Model)
            {
                <tr>
                    <td>@user.UserId</td>
                    <td>@user.UserName</td>
                    <td>@user.Roles</td>
                    <td> @Html.ActionLink("X", "Delete", new { id = @user.UserName }, new {  @class = "deletebtn"})</td>
                </tr>
            }

输出是 System.String[]

4

1 回答 1

2

假设您在应用程序中启用了角色并且您已经创建了一些角色:

using WebMatrix.WebData;
///blah blah blah...

///inside some action:
var roles = (SimpleRoleProvider)Roles.Provider;

var allRoles = roles.GetAllRoles();

获取特定用户的角色:

var userRoles = roles.GetRolesForUser("admin@user.com");

回答你的新问题,试试这个:

var model = ctx.UserProfiles.OrderBy(x => x.UserId);
var newModel = from ab in model
            select new 
            {
                UserName = ab.UserName,
                UserId = ab.UserId,
                Role = roles.GetRolesForUser(ab.UserName)
            };

您正在为已经声明的变量赋值,并且显然数据类型不匹配。

于 2013-08-24T23:22:58.670 回答