C # Как добавить запись в LDAP с несколькими классами объектов - PullRequest
4 голосов
/ 23 апреля 2010

Я пытаюсь создать новую запись пользователя в OpenLDAP с классами объектов person и uidObject .Кажется, проблема в том, что с System.DirectoryServices.DirectoryEntry я нашел только способ добавить новую запись с одним классом объекта, но не способ добавить несколько классов объектов.

Этот код C #

DirectoryEntry nRoot = new DirectoryEntry(path);
nRoot.AuthenticationType = AuthenticationTypes.None;
nRoot.Username = username;
nRoot.Password = pwd;

try
{
    DirectoryEntry newUser = nRoot.Children.Add("CN=" + "test", "person");
    newUser.Properties["cn"].Add("test");
    newUser.Properties["sn"].Add("test");
    newUser.Properties["objectClass"].Add("uidObject"); // this doesnt't make a difference
    newUser.Properties["uid"].Add("testlogin"); // this causes trouble
    newUser.CommitChanges();
}
catch (COMException ex)
{
    Console.WriteLine(ex.ErrorCode + "\t" + ex.Message);
}

... приводит к ошибке:

-2147016684 Запрошенная операция не удовлетворяет одному или нескольким ограничениям, связанным с классом объекта.(Исключение из HRESULT: 0x80072014)

1 Ответ

6 голосов
/ 23 апреля 2010

Оказывается, что вы можете добавить классы объектов после , запись была сначала сохранена в LDAP и извлечена снова.Итак, с простым изменением все работает просто отлично!

DirectoryEntry newUser = nRoot.Children.Add("CN=" + "test", "person");
newUser.Properties["cn"].Add("test");
newUser.Properties["sn"].Add("test");
newUser.CommitChanges();

newUser.RefreshCache();
newUser.Properties["objectClass"].Add("uidObject");
newUser.Properties["uid"].Add("testlogin");
newUser.CommitChanges();
...