Создание локальной учетной записи пользователя c # и .NET 2.0 - PullRequest
20 голосов
/ 21 декабря 2008

Как я могу создать учетную запись локального пользователя, используя .NET 2.0 и c #, а также иметь возможность установить «Пароль никогда не истекает» никогда.

Я пытался использовать «Net.exe», используя Process.Start и передавая его параметры, но кажется, что «сетевой пользователь» не может установить «Пароль никогда не истекает» никогда.

Ответы [ 3 ]

22 голосов
/ 21 декабря 2008

Прочитайте эту превосходную статью CodeProject

Howto: (почти) все в Active Directory через C #

Имеется раздел «Создание учетной записи пользователя» и «Работа с паролями пользователя».

UPDATE:

Чтобы адаптировать код для локальных учетных записей, замените соответствующие строки на эти:

DirectoryEntry localMachine = new DirectoryEntry("WinNT://" + 
    Environment.MachineName);
DirectoryEntry newUser = localMachine.Children.Add("localuser", "user");

Здесь начинается фрагмент исходного кода для учетных записей домена:

public string CreateUserAccount(string ldapPath, string userName, 
    string userPassword)
{
    string oGUID = string.Empty;
    try
    {          
        string connectionPrefix = "LDAP://" + ldapPath;
        DirectoryEntry dirEntry = new DirectoryEntry(connectionPrefix);
        DirectoryEntry newUser = dirEntry.Children.Add
            ("CN=" + userName, "user");
        newUser.Properties["samAccountName"].Value = userName;

        int val = (int)newUser.Properties["userAccountControl"].Value; 
        newUser.Properties["userAccountControl"].Value = val | 0x10000; 

        newUser.CommitChanges();
        oGUID = newUser.Guid.ToString();

        newUser.Invoke("SetPassword", new object[] { userPassword });
        newUser.CommitChanges();

        dirEntry.Close();
        newUser.Close();
    }
    catch (System.DirectoryServices.DirectoryServicesCOMException E)
    {
        //DoSomethingwith --> E.Message.ToString();    
    }
    return oGUID;
}

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

Пожалуйста, обратитесь к этому великому Статья MSDN: Управление паролями пользователей для примеров и документации относительно этих функций.

CONST                          HEX
------------------------------------------
SCRIPT                         0x0001
ACCOUNTDISABLE                 0x0002
HOMEDIR_REQUIRED               0x0008
LOCKOUT                        0x0010
PASSWD_NOTREQD                 0x0020
PASSWD_CANT_CHANGE             0x0040
ENCRYPTED_TEXT_PWD_ALLOWED     0x0080
TEMP_DUPLICATE_ACCOUNT         0x0100
NORMAL_ACCOUNT                 0x0200
INTERDOMAIN_TRUST_ACCOUNT      0x0800
WORKSTATION_TRUST_ACCOUNT      0x1000
SERVER_TRUST_ACCOUNT           0x2000
DONT_EXPIRE_PASSWORD           0x10000
MNS_LOGON_ACCOUNT              0x20000
SMARTCARD_REQUIRED             0x40000
TRUSTED_FOR_DELEGATION         0x80000
NOT_DELEGATED                  0x100000
USE_DES_KEY_ONLY               0x200000
DONT_REQ_PREAUTH               0x400000
PASSWORD_EXPIRED               0x800000
TRUSTED_TO_AUTH_FOR_DELEGATION 0x1000000
21 голосов
/ 24 марта 2009

Этот код создаст локальную учетную запись с установленным параметром пароля, который никогда не истекает:

        using System.DirectoryServices;

        DirectoryEntry hostMachineDirectory = new DirectoryEntry("WinNT://localhost");
        DirectoryEntries entries = hostMachineDirectory.Children;
        bool userExists = false;
        foreach (DirectoryEntry each in entries)
        {
            userExists = each.Name.Equals("NewUser",  
            StringComparison.CurrentCultureIgnoreCase);
            if (systemtestUserExists)
                break;
        }

        if (false == userExists)
        {
            DirectoryEntry obUser = entries.Add("NewUser", "User");
            obUser.Properties["FullName"].Add("Local user");
            obUser.Invoke("SetPassword", "abcdefg12345@");
            obUser.Invoke("Put", new object[] {"UserFlags", 0x10000});
            obUser.CommitChanges();
        }

Флаг 0x10000 означает PasswordNeverExpires.

Я долго размышлял, как создать учетную запись локального пользователя с паролем, срок действия которого не истекает. Кажется, что при попытке использовать:

int val = (int)newUser.Properties["userAccountControl"].Value; 
newUser.Properties["userAccountControl"].Value = val | 0x10000

разрешения из активного каталога вступают в игру. Если у вас есть права доступа к активному каталогу, все работает нормально. Если этого не сделать, свойство userAccountControl всегда будет иметь нулевое значение. Попытка установить userAccountControl приведет к исключению «Не удается найти свойство каталога в кэше».

Однако после долгих поисков я нашел другое свойство "UserFlags", которое нужно установить с помощью Invoke. Вы можете использовать это, чтобы установить флаг для локальной учетной записи. Я пробовал этот код, и он работал на Windows Server 2008.

Надеюсь, это поможет

0 голосов
/ 28 февраля 2013

с использованием System.DirectoryServices;

    DirectoryEntry hostMachineDirectory = new DirectoryEntry("WinNT://localhost");
    DirectoryEntries entries = hostMachineDirectory.Children;
    bool userExists = false;
    foreach (DirectoryEntry each in entries)
    {
        userExists = each.Name.Equals("NewUser",  
        StringComparison.CurrentCultureIgnoreCase);
        if (systemtestUserExists)
            break;
    }

    if (false == userExists)
    {
        DirectoryEntry obUser = entries.Add("NewUser", "User");
        obUser.Properties["FullName"].Add("Local user");
        obUser.Invoke("SetPassword", "abcdefg12345@");
        obUser.Invoke("Put", new object[] {"UserFlags", 0x10000});
        obUser.CommitChanges();
...