VC/Delphi怎样根据pid获取进程用户名?
VC/Delphi怎样根据pid获取进程用户名?不要wmi,也不要根据进程名的。VC请不要有WtsApi32.h,这东西我没有。...
VC/Delphi怎样根据pid获取进程用户名?不要wmi,也不要根据进程名的。VC请不要有WtsApi32.h,这东西我没有。
展开
1个回答
展开全部
Function GetProcessUser(hprocess: THandle): String;
Type
PTokenUser = ^TTokenUser;
_TOKEN_USER = Record
User: TSIDAndAttributes;
End;
TTokenUser = _TOKEN_USER;
Var
hToken: THandle;
dwSize, dwUserSize, dwDomainSize: DWORD;
pUser: PTokenUser;
szUserName, szDomainName: Array Of Char;
peUse: SID_NAME_USE;
Begin
If Not OpenProcessToken(hprocess, TOKEN_QUERY, hToken) Then
Exit;
GetTokenInformation(hToken, TokenUser, Nil, 0, dwSize);
pUser := Nil;
ReallocMem(pUser, dwSize);
dwUserSize := 0;
dwDomainSize := 0;
If Not GetTokenInformation(hToken, TokenUser, pUser, dwSize, dwSize) Then
Exit;
LookupAccountSid(Nil, pUser.User.Sid, Nil, dwUserSize, Nil, dwDomainSize, peUse);
If (dwUserSize <> 0) And (dwDomainSize <> 0) Then
Begin
SetLength(szUserName, dwUserSize);
SetLength(szDomainName, dwDomainSize);
LookupAccountSid(Nil, pUser.User.Sid, PChar(szUserName), dwUserSize, PChar(szDomainName), dwDomainSize, peUse);
End;
Result := PChar(szDomainName) + '\' + PChar(szUserName);
CloseHandle(hToken);
FreeMem(pUser);
End;
Type
PTokenUser = ^TTokenUser;
_TOKEN_USER = Record
User: TSIDAndAttributes;
End;
TTokenUser = _TOKEN_USER;
Var
hToken: THandle;
dwSize, dwUserSize, dwDomainSize: DWORD;
pUser: PTokenUser;
szUserName, szDomainName: Array Of Char;
peUse: SID_NAME_USE;
Begin
If Not OpenProcessToken(hprocess, TOKEN_QUERY, hToken) Then
Exit;
GetTokenInformation(hToken, TokenUser, Nil, 0, dwSize);
pUser := Nil;
ReallocMem(pUser, dwSize);
dwUserSize := 0;
dwDomainSize := 0;
If Not GetTokenInformation(hToken, TokenUser, pUser, dwSize, dwSize) Then
Exit;
LookupAccountSid(Nil, pUser.User.Sid, Nil, dwUserSize, Nil, dwDomainSize, peUse);
If (dwUserSize <> 0) And (dwDomainSize <> 0) Then
Begin
SetLength(szUserName, dwUserSize);
SetLength(szDomainName, dwDomainSize);
LookupAccountSid(Nil, pUser.User.Sid, PChar(szUserName), dwUserSize, PChar(szDomainName), dwDomainSize, peUse);
End;
Result := PChar(szDomainName) + '\' + PChar(szUserName);
CloseHandle(hToken);
FreeMem(pUser);
End;
追问
有没有直接用pid的?这个用的是句柄
追答
Function GetProcessUser(PID: DWORD): String;
Type
PTokenUser = ^TTokenUser;
_TOKEN_USER = Record
User: TSIDAndAttributes;
End;
TTokenUser = _TOKEN_USER;
Var
hToken: THandle; dwSize, dwUserSize, dwDomainSize: DWORD;
pUser: PTokenUser; szUserName, szDomainName: Array Of Char;
peUse: SID_NAME_USE;
hprocess: THandle;
Begin
hprocess := OpenProcess(PROCESS_QUERY_INFORMATION, False, PID);
If hprocess 0 Then
Begin
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
大雅新科技有限公司
2024-11-19 广告
2024-11-19 广告
这方面更多更全面的信息其实可以找下大雅新。深圳市大雅新科技有限公司从事KVM延长器,DVI延长器,USB延长器,键盘鼠标延长器,双绞线视频传输器,VGA视频双绞线传输器,VGA延长器,VGA视频延长器,DVI KVM 切换器等,优质供应商,...
点击进入详情页
本回答由大雅新科技有限公司提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询