[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[转载代码] [PowerShell每日技巧]查看本地用户(20131223)

Did you know that you can actually search for local user accounts, much like you can search for domain accounts?

Here is an example code that searches for all local accounts with a name that starts with "A" and are enabled:
  1. Add-Type -AssemblyName System.DirectoryServices.AccountManagement
  2. $type = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext('Machine', $env:COMPUTERNAME)
  3. $UserPrincipal = New-Object System.DirectoryServices.AccountManagement.UserPrincipal($type)
  4. # adjust your search criteria here:
  5. $UserPrincipal.Name = 'A*'
  6. # you can add even more:
  7. $UserPrincipal.Enabled = $true
  8. $searcher = New-Object System.DirectoryServices.AccountManagement.PrincipalSearcher
  9. $searcher.QueryFilter = $UserPrincipal
  10. $results = $searcher.FindAll();
  11. $results | Select-Object -Property Name, LastLogon, Enabled
复制代码
Likewise, to find all enabled local accounts with a password that never expires, try this:
  1. Add-Type -AssemblyName System.DirectoryServices.AccountManagement
  2. $type = New-Object -TypeName System.DirectoryServices.AccountManagement.PrincipalContext('Machine', $env:COMPUTERNAME)
  3. $UserPrincipal = New-Object System.DirectoryServices.AccountManagement.UserPrincipal($type)
  4. # adjust your search criteria here:
  5. $UserPrincipal.PasswordNeverExpires = $true
  6. $UserPrincipal.Enabled = $true
  7. $searcher = New-Object System.DirectoryServices.AccountManagement.PrincipalSearcher
  8. $searcher.QueryFilter = $UserPrincipal
  9. $results = $searcher.FindAll();
  10. $results | Select-Object -Property Name, LastLogon, Enabled, PasswordNeverExpires
复制代码
http://powershell.com/cs/blogs/tips/archive/2013/12/23/searching-for-local-user-accounts.aspx

返回列表