函数参考


_WinAPI_GetProcessUser

获取指定进程的用户名和域名

#Include <WinAPIEx.au3>
_WinAPI_GetProcessUser ( [$PID] )

参数

$PID [可选参数] 进程标识. 默认0为当前进程.

返回值

成功: 包含下列信息的数组:
[0] 用户(账户)名
[1] 域名
失败: 返回 0并设置@error非0

注意/说明

对一些进程使用该函数需要完全访问权限.
在使用_WinAPI_GetProcessUser()函数前可使用_WinAPI_AdjustTokenPrivileges()函数开启SeDebugPrivilege权限.

相关

详情参考

None

示例/演示


#RequireAdmin

#Include <APIConstants.au3>
#Include <Array.au3>
#Include <WinAPIEx.au3>

Opt('MustDeclareVars', 1)

Global $hToken, $Data, $aAdjust, $aList = 0

; 为获取对其他进程的完全访问权限而启用 "SeDebugPrivilege" 特权
$hToken = _WinAPI_OpenProcessToken(BitOR($TOKEN_ADJUST_PRIVILEGES, $TOKEN_QUERY))
_WinAPI_AdjustTokenPrivileges($hToken, $SE_DEBUG_NAME, $SE_PRIVILEGE_ENABLED, $aAdjust)

; 为系统上所有进程获取用户名
If Not (@error Or @extended) Then
    $aList = ProcessList()
    For $i = 1 To $aList[0][0]
        $Data = _WinAPI_GetProcessUser($aList[$i][1])
        If IsArray($Data) Then
            $aList[$i][1] = $Data[0]
        Else
            $aList[$i][1] = ''
        EndIf
    Next
EndIf

; 默认情况下启用 SeDebugPrivilege 特权
_WinAPI_AdjustTokenPrivileges($hToken, $aAdjust, 0, $aAdjust)
_WinAPI_CloseHandle($hToken)

_ArrayDisplay($aList, '_WinAPI_GetProcessUser')