我需要在
Windows 2008服务器上创建多个用户,并将密码到期值修改为“从不”.这些将是本地(非AD)用户.我可以使用“net user”创建它们,它正在修改杀死我的通过期限.如果我执行“净用户用户名”,它会列出字段及其值,但没有开关(至少没有帮助文件引用的那个)来修改它,我在网上看到的大多数解决方案建议安装第三方工具但是,此解决方案必须是Windows原生的(理想情况下使用Powershell).任何帮助表示赞赏.
UPDATE
我说如果我在Powershell中想出如何做到这一点,我会把它发布在这里,我是一个言行一致的人.
Get-WmiObject -Class Win32_UserAccount -Filter“name =’steve’”| Set-WmiInstance -Argument @ {PasswordExpires = 0}
这是一个布尔值,所以如果你想设置一个密码到期只需将0改为1.这对我来说很简单,我测试了这个方法更新其他WMI对象,它每次都有效.
简单的解决方案是创建一个发出以下命令的批处理文件:
net accounts /maxpwage:unlimited
但是,这会将本地计算机上所有帐户的最长密码期限设置为无限制,而不仅仅是您创建的新帐户.
如果您需要更精细的控制级别(即,为各个用户设置密码到期值的能力),您将需要更复杂的东西. VBScript的Scripting Guys share an example将修改本地用户帐户,以使其密码永不过期:
Const ADS_UF_DONT_EXPIRE_PASSWD = &h10000 strDomainOrWorkgroup = "Fabrikam" strComputer = "atl-win2k-01" strUser = "KenMeyer" Set objUser = GetObject("WinNT://" & strDomainOrWorkgroup & "/" & _ strComputer & "/" & strUser & ",User") objUserFlags = objUser.Get("UserFlags") objPasswordExpirationFlag = objUserFlags OR ADS_UF_DONT_EXPIRE_PASSWD objUser.Put "userFlags",objPasswordExpirationFlag objUser.SetInfo
可以很容易地将其修改为适合您选择的任何用户,甚至可以创建新用户.
最后,here’s an example in C#,您应该能够移植到PowerShell.我不是PS专家,但考虑到它使用.NET Framework,上面的代码应该给你一些想法.