在使用Membership.GetAllUsers()获取到MembershipUser的集合后,可以很方便的使用。
foreach (MembershipUser user in Membership.GetAllUsers())
{
if (user.IsLockedOut)
{
...
}
}
{
if (user.IsLockedOut)
{
...
}
}
但是上面的代码里面,将会出现一个数据错误的bug,如果你的用户里面有一个是IsLockedOut为true的,
那么在集合排在这个用户后面的用户这个属性也都为true。
举个例子吧:
user1: 张三,zs@dd.com,true(IsApproved),false(IsLockedOut)
user2: 里斯,ls@zz.com,true(IsApproved),true(IsLockedOut)
user3: 思凡,hah@d.com,true(IsApproved),true(IsLockedOut)
user4: 学弟,do@co.com,true(IsApproved),true(IsLockedOut)
事实上,只有“里斯”是被锁定的,所以列表里面在里斯后面的这个属性也变了。
当然你如果使用 Membership.GetUser(“学弟”)仍然可以得到真实的所有数据。
测试环境:vs2008 oracle 11g odp.net 1110621