Etki alanı hesaplarıyla aradığınızı yapmak için bazı PowerShell kodu:
param (
[string]$oldPassword = $( Read-Host "Old password"),
[string]$newPassword = $( Read-Host "New password")
)
$ADSystemInfo = New-Object -ComObject ADSystemInfo
$type = $ADSystemInfo.GetType()
$user = [ADSI] "LDAP://$($type.InvokeMember('UserName', 'GetProperty', $null, $ADSystemInfo, $null))"
$user.ChangePassword( $oldPassword, $newPassword)
ASDI sağlayıcısı WinNT://computername/username
, ChangePassword()
yöntemin sözdizimini de destekler . Ancak ADSystemInfo
nesne, makine yerel hesapları için çalışmaz, bu nedenle yukarıdaki kodu sadece WinNT://...
sözdizimi ile uyarlamak uygulanabilir değildir.
(Yerel ve alan adı hesapları arasında ayrım yapmak için bir kod w / düzenleme önermek isteyen var mı?)
Tamamen farklı bir çakışmada, eski NetUserChangePassword
API yerel (ve etki alanı, NetBIOS sözdiziminde etki alanı adını belirtmeniz koşuluyla) hesaplarında da çalışır:
param (
[string]$oldPassword = $( Read-Host "Old password"),
[string]$newPassword = $( Read-Host "New password")
)
$MethodDefinition = @'
[DllImport("netapi32.dll", CharSet = CharSet.Unicode)]
public static extern bool NetUserChangePassword(string domainname, string username, string oldPassword, string newPassword);
'@
$NetAPI32 = Add-Type -MemberDefinition $MethodDefinition -Name 'NetAPI32' -Namespace 'Win32' -PassThru
$NetAPI32::NetUserChangePassword('.', $env:username, $oldPassword, $newPassword)
Bu kod, yerel makinedeki bir şifreyi değiştirdiğinizi varsayar (".").