如何最好地在成员资格提供程序上实现自定义搜索

Geo*_*rzi 8 asp.net-membership

开箱即用,System.Web.Security.Membership实现了几种搜索方法:

  • FindUsersByEmail
  • FindUsersByName

我正在使用CodePlexWSAT项目来管理我的会员数据库.该工具在ProfileCommon类中实现额外的配置文件属性.

假设我在用户的个人资料中有一个名为Firm的属性.

我需要实现一个自定义搜索方法来搜索Firm属性,我想在代码中完成所有这些操作.不想编写存储过程(因为所有配置文件属性都存储在WSAT工具的1个数据库列中).

这样的事情显然不是正确的方法,但这里只是演示访问用户的配置文件属性:

    private MembershipUserCollection SearchByFirm(string firmName, MembershipUserCollection allRegisteredUsers)
{
    MembershipUserCollection searchResults = new MembershipUserCollection();

    foreach (MembershipUser user in allRegisteredUsers)
    {
        ProfileCommon profile = Profile.GetProfile(user.UserName);
        if (profile.Firm.ToLowerInvariant().Contains(firmName.ToLowerInvariant()))
        {
            searchResults.Add(user);
        }
    }
    return searchResults;
}
Run Code Online (Sandbox Code Playgroud)

我可以把它变成一些LINQ善良吗?

小智 22

那你不能投吧吗?

IEnumerable<MembershipUser> searchResults = Membership.GetAllUsers().Cast<MembershipUser>();
Run Code Online (Sandbox Code Playgroud)

希望这可以帮助你们


Geo*_*rzi 3

从擅长 linq 的同事那里得到了一些帮助。这里的挑战是 MembershipUserCollection 没有实现 IEnumerable< T > (!)。

        List<MembershipUser> searchResults = allUsers.Where(user => 
        Profile.GetProfile(user.UserName).Firm.ToLowerInvariant()
        .Contains(firmName.ToLowerInvariant())).ToList();
Run Code Online (Sandbox Code Playgroud)

在本例中,allUsers 是一个列表,我必须使用 Membership.GetAllUsers() 集合中的项目填充该列表。