加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net c#membership:如何做一个GetUsersInRoles(多个角色)H

发布时间:2020-12-16 04:12:40 所属栏目:asp.Net 来源:网络整理
导读:我想做一个“GetUsersInRoles”,即我想找到所有MembershipUser在一组角色中至少有一个角色,但我似乎无法理解这个角色. 我有GetUsersInRole,Membership.GetAllUsers(),Linq,……但是怎么样? 任何反馈都非常感谢 汤米 解决方法 这是一个Linq版本,它返回一个Me
我想做一个“GetUsersInRoles”,即我想找到所有MembershipUser在一组角色中至少有一个角色,但我似乎无法理解这个角色.

我有GetUsersInRole,Membership.GetAllUsers(),Linq,……但是怎么样?

任何反馈都非常感谢

汤米

解决方法

这是一个Linq版本,它返回一个MembershipUserCollection,就像类似的Membership方法(FindUsersByEmail,FindUsersByName)一样.它不是很漂亮,因为它依赖于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;
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读