您正在混合兩個分享大量重疊的獨立環境。 DirectoryEntry是DirectoryServices包的一部分,GetObject是一個與ActiveDs.dll接口的VBA工具。
如果這需要視覺基本腳本,那麼您具有來自GetObject()或Find()方法的DirectoryEntry的等價物。如果您需要訪問屬性,請使用object.Get(「property_name」)方法(返回多值屬性的數組)
如果您可以將開發平臺交換爲.NET,您將可以訪問所有DirectoryServices想。
編輯:如果這是一個C#.NET應用程序,這裏的使用
private static DirectoryEntry getGroupDE(String group)
{
String adserver = "dc.companyname.com";
String searchroot = "ou=Groups,dc=companyname,dc=com";
DirectorySearcher ds = new DirectorySearcher();
ds.SearchRoot = new DirectoryEntry(String.Format("LDAP://{0}/{1}",adserver,searchroot));
ds.SearchScope = SearchScope.Subtree;
ds.Filter = String.Format("(&(objectCategory=group)(sAMAccountName={0}))",group);
SearchResult sr = ds.FindOne();
if (sr == null)
{
return null;
}
return sr.GetDirectoryEntry();
}
看一看我的[海狸ADSI瀏覽器](代碼http://adsi.mvps.org/adsi/CSharp /beavertail.html) - 它顯示了AD層次結構以及LDAP路徑的所有相關信息。 – 2012-04-02 12:12:35
'strGroup'是否是專有名稱?像CN = Domain-Users,CN = Users,DC = test1'? – Tschareck 2012-04-02 12:31:30
「名稱」實際上應該是其容器內對象的「本地」名稱。所以它可能是'OU = TestOU'容器內的CN = TestGroup'或其他東西。它只是您要查找的對象的本地名稱 - 只是本地名稱,*不是*整個長LDAP路徑.... – 2012-04-02 13:38:22