利用DirectoryEntry获取域内计算机以及共享资源
本文于 1786 天之前发表
前言
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发现机器上的共享资源。
C#实现代码
以下为Ladon的EnumShare代码,自动获取当前域,并枚举域内计算机以及获取机器开放共享资源。
1 | string strDomain; |
Ladon EnumShare
因为崇尚极简主义,所以Ladon无需填写域名以及参数,参数多也很烦,全自动获取,一步到位。
参考
https://github.com/k8gege/Ladon
转载声明
K8博客文章随意转载,转载请注明出处! © K8gege http://k8gege.org

扫码加入K8小密圈