WMI是Windows管理規(guī)范的縮寫,其中包含很多系統(tǒng)的軟硬件信息。而Windows用戶信息也可以通過(guò)WMI對(duì)象來(lái)獲取。PowerShell提供了對(duì)WMI的訪問(wèn)功能,十分方便且強(qiáng)大——這就是Get-WmiObject這個(gè)cmdlet。
獲取所有的Windows用戶列表:
Get-WmiObject -Class Win32_UserAccount 或者 Get-WmiObject
復(fù)制代碼 代碼如下:
Win32_UserAccount
如果是想知道查看當(dāng)前登錄的用戶的信息,可以用如下語(yǔ)句:
復(fù)制代碼 代碼如下:
Get-WmiObject -Class Win32_UserAccount -Filter "Name='$env:username' and Domain='$env:userdomain'"
其中$env:username表示當(dāng)前登錄到系統(tǒng)的用戶名,而$env:userdomain表示當(dāng)前用戶的域(或者機(jī)器名)。
上面的語(yǔ)句其實(shí)只顯示用戶的基本信息,如果想看用戶更詳細(xì)的信息,可以把查出來(lái)的用戶當(dāng)成一個(gè)對(duì)象,使用Select-Object方法,查看它的全部信息。
復(fù)制代碼 代碼如下:
Get-WmiObject -Class Win32_UserAccount -Filter "Name='$env:username' and Domain='$env:userdomain'" | Select-Object *
得到的信息將像這樣:
復(fù)制代碼 代碼如下:
Status : OK
Caption : hong-book\hong
PasswordExpires : False
__GENUS : 2
__CLASS : Win32_UserAccount
__SUPERCLASS : Win32_Account
__DYNASTY : CIM_ManagedSystemElement
__RELPATH : Win32_UserAccount.Domain="hong-book",Name="hong"
__PROPERTY_COUNT : 16
__DERIVATION : {Win32_Account, CIM_LogicalElement, CIM_ManagedSystemElement}
__SERVER : HONG-BOOK
__NAMESPACE : root\cimv2
__PATH : \\HONG-BOOK\root\cimv2:Win32_UserAccount.Domain="hong-book",Name="hong"
AccountType : 512
Description :
Disabled : False
Domain : hong-book
FullName :
InstallDate :
LocalAccount : True
Lockout : False
Name : hong
PasswordChangeable : True
PasswordRequired : False
SID : S-1-5-21-181061805-855091228-1216038997-1000
SIDType : 1
Scope : System.Management.ManagementScope
Path : \\HONG-BOOK\root\cimv2:Win32_UserAccount.Domain="hong-book",Name="hong"
Options : System.Management.ObjectGetOptions
ClassPath : \\HONG-BOOK\root\cimv2:Win32_UserAccount
Properties : {AccountType, Caption, Description, Disabled...}
SystemProperties : {__GENUS, __CLASS, __SUPERCLASS, __DYNASTY...}
Qualifiers : {dynamic, Locale, provider, UUID}
Site :
Container :
利用對(duì)象提供的這些屬性信息,我們可以做很多事情,比如我們想看看當(dāng)前小編登錄的賬號(hào)的密碼是否已過(guò)期,則可以寫這樣一個(gè)函數(shù):
復(fù)制代碼 代碼如下:
function Test-UserPasswordExpires
{
param(
$UserName = $env:username,
$Domain = $env:userdomain
)
(Get-WmiObject -Class Win32_UserAccount -Filter "Name='$UserName' and Domain='$Domain'").PasswordExpires
}
好了,關(guān)于用戶信息差不多就這么多,小編祝大家使用愉快!
您可能感興趣的文章:- php curl登陸qq后獲取用戶信息時(shí)證書錯(cuò)誤
- 微信開(kāi)發(fā)之網(wǎng)頁(yè)授權(quán)獲取用戶信息(二)