8

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

  • 通过电子邮件查找用户
  • 按名称查找用户

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

假设我在用户的个人资料中有一个名为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;
}

我可以把它变成一些 LINQ 的优点吗?

4

4 回答 4

22

那么你不能直接投吗?

IEnumerable<MembershipUser> searchResults = Membership.GetAllUsers().Cast<MembershipUser>();

希望这对你们有帮助

于 2009-04-23T09:36:06.283 回答
3

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

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

在这种情况下 allUsers 是一个列表,我必须用 Membership.GetAllUsers() 集合中的项目填充它。

于 2009-01-07T22:24:16.543 回答
0

只是为了记录,我创建了这个扩展方法,我认为它有点工作:

namespace WebDibaelsaMVC.Utils.MembershipUserCollectionExtensions
{
    public static class MembershipUserCollectionExtensions
    {
        public static IEnumerable<MembershipUser> Where(this MembershipUserCollection userCollection,Func<MembershipUser,bool> func)
        {
            foreach (MembershipUser membershipUser in userCollection)
            {
                 if (func(membershipUser))
                    yield return membershipUser;
            }
        }
    }
}

它还将 转换为MembershipUserCollectionIEnumerable<MembershipUser>以便所有其他 LINQ 方法在之后工作。

于 2009-10-22T17:04:49.103 回答
0

微软没有提供内置功能。这是具有用户名和电子邮件地址的搜索会员用户
示例:
只需复制下面的功能并实现它 - 完成...

Public List<MembershipUser> SearchMembershipUser(string strUserName, String strEmail)
        {           
            IEnumerable<MembershipUser> MUser;
            if ((!string.IsNullOrEmpty(strUserName) || !string.IsNullOrEmpty(strEmail)))
            {
                if (!string.IsNullOrEmpty(strUserName) && !string.IsNullOrEmpty(strEmail))
                {
                    MUser = Membership.GetAllUsers().Cast<MembershipUser>()
                        .Where(x => x.UserName != CurrentUser && x.UserName == strUserName && x.Email == strEmail);
                }
                else if (!string.IsNullOrEmpty(strUserName))
                {
                    MUser = Membership.GetAllUsers().Cast<MembershipUser>()
                        .Where(x => x.UserName != CurrentUser && x.UserName == strUserName);
                }
                else
                {
                    MUser = Membership.GetAllUsers().Cast<MembershipUser>()
                        .Where(x => x.UserName != CurrentUser && x.Email == strEmail);
                }
            }
            else
            {
                MUser = Membership.GetAllUsers().Cast<MembershipUser>().Where(x => x.UserName != CurrentUser);
            }
            return MUser.OrderBy(x => x.UserName).ToList();
        }
于 2012-10-27T13:00:22.370 回答