ASP.NET C#成员资格:如何执行GetUsersInRoles(多个角色)操作?

7
我想执行一个“GetUsersInRoles”,即我想查找在一组角色中至少有一个角色的所有MembershipUser,但我似乎无法理解这个问题。我已经尝试了GetUsersInRole、Membership.GetAllUsers()和Linq等方法,但是怎么做呢?非常感谢您的任何反馈。
汤米

这段代码如果用存储过程来写大约只需要10秒钟的时间。 - 3Dave
3个回答

10

以下是 Linq 版本,它返回与类似的 Membership 方法(FindUsersByEmailFindUsersByName)相同的 MembershipUserCollection。这个方法并不是很美观,因为它依赖于 ForEach 的副作用:

    public static MembershipUserCollection FindUsersByRole(string[] roles)
    {
        MembershipUserCollection msc = new MembershipUserCollection();

        roles.Select(role => Roles.GetUsersInRole(role))
        .Aggregate((a, b) => a.Union(b).ToArray())
        .Distinct()
        .Select( user => Membership.GetUser(user))
        .ToList().ForEach( user => msc.Add(user));

        return msc;
    }

或者如果一个 MembershipUser 列表可以使用:

    public static List<MembershipUser> FindUsersByRole(string[] roles)
    {
        var userList = roles.Select(role => Roles.GetUsersInRole(role))
                            .Aggregate((a, b) => a.Union(b).ToArray())
                            .Distinct()
                            .Select( user => Membership.GetUser(user))
                            .ToList();
        return userList;
    }  

最后,如果你只需要用户名,你可以跳过一个查询:

    public static List<string> FindUsersByRole(string[] roles)
    {
        var userList = roles.Select(role => Roles.GetUsersInRole(role))
                            .Aggregate((a, b) => a.Union(b).ToArray())
                            .Distinct()
                            .ToList();
        return userList;
    }

非常感谢您的回复和快速答复。不幸的是,我无法添加“有用性”积分,因为我自己没有声望积分。 - tommyp

1

没有GetUsersInRoles这样的方法,但是你可以使用GetUsersInRole并循环遍历所需的角色。

有点复杂,但以下是一种方法:

string[] roles = {"role1", "role2" };
        string[] tempusers = new string[]{};
        List<string> users = new List<string>();
        foreach (string role in roles)
        {
            string[] usersInRole = Roles.GetUsersInRole(role);
            users =  tempusers.Union(usersInRole).ToList();
            tempusers = users.ToArray();
        }
        foreach (string user in users) { Response.Write(user + "<br/>"); }

没错 - 这正是我在寻找的一个不错的方式,最好使用 Linq。 - tommyp

1

实际上,ASP.Net成员资格提供程序似乎是建立在用户与单个角色绑定的思想上。然而,在我们所参与的项目中,我们也有类似的设置。虽然有点尴尬,但您可以尝试像这样的解决方案,这对我们很有效:

 List<string> roleset_to_find = new List<string>() {"RoleA","RoleB"};

 List<string> membersFound = new List<string>();

 foreach (string role in roleset_to_find)
 {
      membersFound.AddRange(Roles.GetUsersInRole(role));
 }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接