Geo*_*rzi 8 asp.net-membership
开箱即用,System.Web.Security.Membership实现了几种搜索方法:
我正在使用CodePlex的WSAT项目来管理我的会员数据库.该工具在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)
希望这可以帮助你们
从擅长 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() 集合中的项目填充该列表。
归档时间: |
|
查看次数: |
2905 次 |
最近记录: |