如何编写脚本来修改Windows Server上用户的密码到期值?

前端之家收集整理的这篇文章主要介绍了如何编写脚本来修改Windows Server上用户的密码到期值?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我需要在 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,上面的代码应该给你一些想法.

猜你在找的Windows相关文章