我创建了这个函数来获取各种网络进程的路径,比如svchost,Firefox等.这是代码:
function GetProcesspath(var pId:Integer):String; var Handle: THandle; begin Result := ''; try Handle := OpenProcess(PROCESS_QUERY_informatION or PROCESS_VM_READ,False,pID); if Handle <> 0 then begin try SetLength(Result,MAX_PATH); if GetmodulefileNameEx(Handle,PChar(Result),MAX_PATH) > 0 then SetLength(Result,StrLen(PChar(Result))) else Result := ''; finally CloseHandle(Handle); end; end; except on E:Exception do ShowMessage(E.ClassName + ':' + E.Message); end; end;
我的问题是我没有得到所有进程的路径.它适用于获取Firefox和其他类似用户级进程的路径.但对于像alg,Svchost这样的进程,我无法通过这种方法获得路径.我的猜测是我必须使用一些不同的API.我该如何解决这个问题?
我使用的是Windows XP,32位.
解决方法
您需要设置调试权限.以下是它的完成方式:
function NTSetPrivilege(sPrivilege: string; bEnabled: Boolean): Boolean; var hToken: THandle; TokenPriv: TOKEN_PRIVILEGES; PrevTokenPriv: TOKEN_PRIVILEGES; ReturnLength: Cardinal; begin Result := True; // Only for Windows NT/2000/XP and later. if not (Win32Platform = VER_PLATFORM_WIN32_NT) then Exit; Result := False; // Obtain the processes token if OpenProcesstoken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES or TOKEN_QUERY,hToken) then begin try // Get the locally unique identifier (LUID) . if LookupPrivilegeValue(nil,PChar(sPrivilege),TokenPriv.Privileges[0].Luid) then begin TokenPriv.PrivilegeCount := 1; // One privilege to set case bEnabled of True: TokenPriv.Privileges[0].Attributes := SE_PRIVILEGE_ENABLED; False: TokenPriv.Privileges[0].Attributes := 0; end; ReturnLength := 0; // Replaces a var parameter PrevTokenPriv := TokenPriv; // Enable or disable the privilege AdjustTokenPrivileges(hToken,TokenPriv,SizeOf(PrevTokenPriv),PrevTokenPriv,ReturnLength); end; finally CloseHandle(hToken); end; end; end; NtSetPrivilege('SeDebugPrivilege',TRUE); // Call this on form create
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。