Active Directory Показать все свойства в таблице
Я пытаюсь выполнить запрос LDAP, чтобы собрать все свойства, которые у нас есть о наших пользователях, без указания свойств заранее, я хотел бы отобразить это в таблице, поэтому использовал следующий код. Это работает, если я раскомментирую search.PropertiesToLoad.Add (& quot; cn & quot;); и будет отображать любые другие свойства, которые я добавляю таким же образом, но не тогда, когда я делаю полный поиск всех свойств.
DirectoryEntry myLdapConnection = createDirectoryEntry();
DirectorySearcher search = new DirectorySearcher(myLdapConnection);
search.CacheResults = true;
//search.PropertiesToLoad.Add("cn");
SearchResultCollection allResults = search.FindAll();
DataTable resultsTable = new DataTable("Results");
//add columns for each property in results
foreach (string colName in allResults.PropertiesLoaded)
resultsTable.Columns.Add(colName, colName.GetType());
//loop to add records to DataTable
foreach (SearchResult result in allResults)
{
int tmp = result.Properties.Count;
DataRow row = resultsTable.NewRow();
foreach (string columnName in search.PropertiesToLoad)
{
if (columnName.Equals("lastlogon"))
{
if (result.Properties.Contains(columnName))
row[columnName] = ConvertDate(result.Properties[columnName].ToString());
else
row[columnName] = "";
}
else
{
if (result.Properties.Contains(columnName))
row[columnName] = result.Properties[columnName][0].ToString();
else
row[columnName] = "";
}
}
resultsTable.Rows.Add(row);
}
gridResults.DataSource = resultsTable;
Проблема, кажется, с
foreach (string colName in allResults.PropertiesLoaded)
resultsTable.Columns.Add(colName, colName.GetType());
Я ожидал, что это зациклит все свойства, когда не было указано PropertiesToLoad, но это не способ добиться того, чего я хочу.
Я знаю, что пока мне нужно несколько попыток отлова и других фрагментов в коде, это черновик.