簡體   English   中英

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

[英]asp.net c# membership: how to do a GetUsersInRoles (multiple roles)H

我想做一個“GetUsersInRoles”,即我想找到所有MembershipUser在一組角色中至少有一個角色,但我似乎無法理解這個角色。

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

任何反饋都非常感謝

湯米

這是一個Linq版本,它返回一個MembershipUserCollection ,就像類似的Membership方法( FindUsersByEmailFindUsersByName )一樣。 它不是很漂亮,因為它依賴於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;
    }

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/>"); }

實際上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));
 }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM