it-swarm.com.ru

Powershell: как сопоставить сетевой диск с другим именем пользователя/паролем

Справочная информация: Предположим, я использую следующий скрипт powershell с локального компьютера для автоматического сопоставления некоторых сетевых дисков.

$net = $(New-Object -ComObject WScript.Network);
$net.MapNetworkDrive("p:", "\\papabox\files");

$net = $(New-Object -ComObject WScript.Network);
$net.MapNetworkDrive("q:", "\\quebecbox\files");

## problem -- this one does not work because my username/password
## is different on romeobox
$net = $(New-Object -ComObject WScript.Network);
$net.MapNetworkDrive("r:", "\\romeobox\files");

Вопрос: Как мне изменить скрипт, чтобы я также мог подключаться к romeobox, даже если мое имя пользователя/пароль на romeobox отличается от имени других двух окон?

18
dreftymac
$net = new-object -ComObject WScript.Network
$net.MapNetworkDrive("r:", "\\romeobox\files", $false, "domain\user", "password")

Должен сделать трюк,

Kindness,

Дэн

33
Daniel Elliott

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

# Stick password into DPAPI storage once - accessible only by current user
Add-Type -Assembly System.Security
$passwordBytes = [System.Text.Encoding]::Unicode.GetBytes("Open Sesame")
$entropy = [byte[]](1,2,3,4,5)
$encrytpedData = [System.Security.Cryptography.ProtectedData]::Protect( `
                       $passwordBytes, $entropy, 'CurrentUser')
$encrytpedData | Set-Content -enc byte .\password.bin

# Retrieve and decrypted password
$encrytpedData = Get-Content -enc byte .\password.bin
$unencrytpedData = [System.Security.Cryptography.ProtectedData]::Unprotect( `
                       $encrytpedData, $entropy, 'CurrentUser')
$password = [System.Text.Encoding]::Unicode.GetString($unencrytpedData)
$password
12
Keith Hill

Пришел сюда в поисках, как подключить диски с помощью PowerShell? 

Существует более простой способ с PowerShell3.0. New-PSDrive был обновлен с помощью опции -persist. Например. 

New-PSDrive -Name U -PSProvider FileSystem -Root \\yourserver\your\folder -Credential yourdomain\username -Persist

В прошлом New-PSDrive затрагивал только текущий сеанс PowerShell. -persist приводит к тому, что отображение регистрируется в O/S как бы. Смотрите New-PSDrive

Чтобы ответить на исходный вопрос, вы можете изменить используемые учетные данные. Использование -Credential для изменения домена\имени пользователя приводит к тому, что Windows запрашивает пароль. Другой альтернативой является передача объекта PSCredential, как в примере ниже. Смотрите Get-Credential для более подробной информации.

PS C:\> $User = "mydomain\username"
PS C:\> $PWord = ConvertTo-SecureString -String "mypassword" -AsPlainText -Force
PS C:\> $Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $User, $PWord
PS C:\> New-PSDrive -Name U -PSProvider FileSystem -Root \\domain\some\folder -Credential $Credential -Persist  
9
Donal Lafferty

Я обнаружил, что этот легкий лайнер сработал в моем случае (мало "нестандартного" мышления;))

(Start-Process -FilePath "C:\windows\system32\NET.exe" -ArgumentList "USE I:\Server\Volume/USER: XXXXX пароль / persistent: yes" -Wait -Passthru) .ExitCode

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

1
JPand Katie
$User = "user"
$PWord = ConvertTo-SecureString -String "password" -AsPlainText -Force
$Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList $User, $PWord
$net = $(New-Object -ComObject WScript.Network)
$net.MapNetworkDrive("r:", "\\server\share")
1
DisplayName

На моей рабочей станции,

$net.MapNetworkDrive("k", "\\romeobox\files", $false, "domain\username", "password")

отправил мне ошибку:

Исключение составляет «MapNetworkDrive» и аргумент (ы) «5»: «Nom de périph Это местный дежа утилизируется.

Любопытно, что это произошло не от того, что K: уже использовалось, а от "::". Вот что работает на моей рабочей станции:

$net.MapNetworkDrive::("k", "\\romeobox\files", $false, "domain\username", "password")
0
Valentin O.