8

我在 C# 中连接到一个 LDAP 目录,所以我使用了 DirectoryEntry 类。

当您使用地址、登录名和密码执行“新 DirectoryEntry”时,它应该连接到 LDAP 目录。

但是,即使连接不工作,它也会毫无问题地返回,并且设置了 directoryentry 变量。

所以我知道我的连接真的打开了吗?现在,我正在使用一个非常丑陋的 hack:我放了一个“if(mydirectory.SchemaEntry)”,如果连接没有建立,它会生成一个异常,因为 DirectoryEntry 的一些成员,例如 SchemaEntry,是'如果连接失败则不设置。但是 1:那必须是丑陋等级的 11/10 2:在失败之前需要很长时间。

那么这样做的好方法是什么?当然,微软一定提供了一些东西(即使我使用的是 LDAP 目录而不是 Active Directory)来知道我是否真的连接了?

4

4 回答 4

12

只是“更新”一个 DirectoryEntry 不会创建到 LDAP 存储的连接。

只有在您开始使用其属性或.NativeObject显式访问该属性时,您才会真正获得到 LDAP 存储的连接。

为了确保您已连接,只需(DirectoryEntry).NativeObject在 try...catch 子句中读出 - 如果它爆炸了,则说明您有问题,否则您的连接现在已启动并处于活动状态。

不幸的是,据我所知,没有可以调用的属性或方法来确定您是否已使用 DirectoryEntry 成功连接到 LDAP。

马克

于 2009-06-30T14:14:59.867 回答
2

您可以检查 DirectoryEntry.Properties.Count。如果它 > 0,它是一个有效的对象。.Properties 永远不会为空 - 即使您没有连接到有效的 DirectoryEntry,您也可以读取计数,并且有效的 DE 将始终具有至少一个属性。

无需尝试/捕获或异常。

于 2010-10-05T12:56:48.803 回答
1

好的,所以 marc_s 的解决方案与我正在做的差不多(除了我在寻找 SchemaEntry 而不是 NativeObject)。但是超时延迟太长(运行查询以填充表单的自动完成值)。我想我实际上更喜欢假装连接已打开并让查询运行。这样,我可以设置自己的更小超时延迟。

于 2009-07-01T06:37:43.120 回答
1

您可以检查 DirectoryEntry.Properties.Count。如果 > 0,则为有效对象。但是仍然可以说您的 LDAP 服务器已关闭。你不能用它的任何属性来识别它。相反,你可以使用 try catch 块捕获它

try         
{    
     entry = new DirectoryEntry("priorityLDAPServer", sUserName, sPassword, AuthenticationTypes.None);      
   if(entry.Properties.Count > 0) 
   {               
        object o = entry.NativeObject;        
     `   next need to check user record in application database`      
   }
 }        
    catch (System.Runtime.InteropServices.COMException comex)       
{    

 //throws you the error if LDAP   server is down or wrong "Server is invalid "          
 //  you can further do a nested try catch within this block if you to try a     optional LDAP server.*
}       

希望这可以帮助你

于 2015-07-06T10:39:25.637 回答