在使用Membership.GetAllUsers()获取到MembershipUser的集合后,可以很方便的使用。

 

foreach (MembershipUser user in Membership.GetAllUsers())
        {
            
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 

posted on 2010-03-24 14:21  熵星尘  阅读(328)  评论(2编辑  收藏  举报