Удаление учетных записей пользователей Windows удаленно WCF и C # - PullRequest
0 голосов
/ 21 июня 2011

Могу ли я программно и удаленно создавать и удалять учетные записи пользователей Windows через WCF (самостоятельно) и C #?Это работает локально, но не через WCF ... Идеи?

            DirectoryEntry localDirectory = new DirectoryEntry("WinNT://" + Environment.MachineName.ToString());
            DirectoryEntries users = localDirectory.Children;
            try
                {
                    DirectoryEntry user = users.Find(usernameAccount);
                    users.Remove(user);

                }catch(SystemException)
                {
                    System.Console.WriteLine("Error: User account not found in the system");
                }
            }

Ответы [ 2 ]

3 голосов
/ 21 июня 2011

Должно работать, если учетные данные, с которыми работает служба, имеют соответствующие разрешения на удаление учетной записи. Если учетные данные по умолчанию, в которых выполняется код службы, не имеют такого разрешения, вы можете посмотреть на , выдавая себя за клиента , чтобы сделать это.

0 голосов
/ 12 июля 2014

У меня возникла проблема с подключением к удаленным окнам с ошибкой Ошибка (0x80004005): Ошибка не указана.Я решил следующим образом:

//Define path
//This path uses the full path of user authentication
String path = string.Format("WinNT://{0}/{1},user", server_address, username);
DirectoryEntry deBase = null;
try
{
    //Try to connect with secure connection
    deBase = new DirectoryEntry(_ldapBase, _username, _passwd, AuthenticationTypes.Secure);

    //Connection test
    //After test define the deBase with the parent of user (root container)
    object nativeObject = _deRoot.NativeObject;
    _deRoot = _deRoot.Parent;

}
catch (Exception ex)
{
    //If an error occurred try without Secure Connection
    try
    {
        _deRoot = new DirectoryEntry(_ldapBase, _username, _passwd);

        //Connection test
        //After test define the deBase with the parent of user (root container)
        object nativeObject = _deRoot.NativeObject;
        _deRoot = _deRoot.Parent;
        nativeObject = _deRoot.NativeObject;

    }
    catch (Exception ex2)
    {
        //If an error occurred throw the error
        throw ex2;
    }
}
...