System.DirectoryServices.DirectoryEntry组件提供了对Active Directory的访问。本文以两个简单的小程序为例,阐述了如何利用此组件查看网络的各节点的信息。 DirectoryEntry组件提供了Path属性,根据文档,此属性指定了目录服务中用来访问对象的对象名,其格式如下:
protocol://servername:port number/distinguished name
此语句的第一部分定义了访问将使用的协议,如
LDAP: (Lightweight Directory Access Protocol)
IIS: (提供IIS元数据来读及配置Internet Infomation Server)
WinNT: (提供在非常有限的性能下对Windows NT域的访问)
NDS: (提供对Novell Directory Service的访问)
等等(详细信息清参考MSDN)。
因此我们构造一个DirectoryEntry实例,将它的Path设为"WinNT:",以通过对它的所有子项的枚举来发现网络上的所有域(以及工作组)。这样,再对所发现的域(以及工作组)的子项进行枚举,就可以发现网络上的所有计算机,结合WMI发现机器上的共享资源。
以下为Ladon的EnumShare代码,自动获取当前域,并枚举域内计算机以及获取机器开放共享资源。
string strDomain;
string strComputer;
string strShare;
Console.WriteLine("Load EnumShare");
DirectoryEntry root = new DirectoryEntry("WinNT:");
foreach (DirectoryEntry Domain in root.Children)
{
strDomain = Domain.Name;
Console.WriteLine("Domain: " + strDomain);
foreach (DirectoryEntry Computer in Domain.Children)
{
if (Computer.SchemaClassName.Equals("Computer"))
{
strComputer = Computer.Name;
ManagementObjectSearcher searcher = new ManagementObjectSearcher("select * from win32_share");
foreach (ManagementObject share in searcher.Get())
{
strShare = share["Name"].ToString();
Console.WriteLine(strComputer + "\\" + strShare);
}
}
}
}
Ladon EnumShare
因为崇尚极简主义,所以Ladon无需填写域名以及参数,参数多也很烦,全自动获取,一步到位。