zoukankan      html  css  js  c++  java
  • 获得进程可执行文件的路径: GetModuleFileNameEx, GetProcessImageFileName, QueryFullProcessImageName

    http://blog.csdn.net/bichenggui/article/details/4774457

    --------------------------------------------------

    获得进程可执行文件的路径: GetModuleFileNameEx, GetProcessImageFileName, QueryFullProcessImageName

    想获得进程可执行文件的路径通常有三个方法:

    一: 调用GetModuleFileNameEx函数获得可执行文件的模块路径这个函数从Windows NT 4.0开始到现在的Vista系统都能使用,向后兼容性比较好。

    二:调用GetProcessImageFileName函数,这个函数在Windows XP及其以后的系统中都能使用。

    三:调用Windows Vista新增的函数QueryFullProcessImageName,由于是Vista新增的,所以兼容性不好。

    下面来看看这三个函数的原型:


    DWORD GetModuleFileNameEx(HANDLE hProcess,HMODULE hModule,LPTSTR lpFilename,DWORD nSize)
          hProcess是目标进程的句柄、hModule是目标模块的句柄(当此参数为NULL时函数返回的是进程可执行文件的路径)、lpFilename是 存放路径的字符串缓冲区、nSize表示缓冲区的大小。函数调用失败将返回0。注:进程的句柄须有PROCESS_QUERY_INFORMATION和 PROCESS_VM_READ权限。

    DWORD GetProcessImageFileName(HANDLE hProcess,LPTSTR lpImageFileName,DWORD nSize)
          hProcess是目标进程的句柄、lpImageFileName是存放路径的字符串缓冲区、nSize表示缓冲区的大小。函数失败将返回0。注:进程句柄需要有PROCESS_QUERY_INFORMATION的权限。

    BOOL QueryFullProcessImageName(HANDLE hProcess,DWORD dwFlags,LPTSTR lpExeName,PDWORD lpdwSize)
          hProcess是目标进程的句柄、dwFlags一般设为0(表示返回的路径是Win32的路径格式,如"C:/...",如将其设为 PROCESS_NAME_NATIVE将返回"/Device/HarddiskVolume1/..."这样的格式路径)、lpExeName是存放 路径的字符串缓冲区、lpdwSize表示缓冲区的大小。函数失败将返回FALSE。注:调用此函数的句柄须有 PROCESS_QUERY_INFORMATION或这是PROCESS_QUERY_LIMITED_INFORMATION的权限,并且只能在 Vista或更高版本的系统中使用。

          调用GetModuleFileNameExGetProcessImageFileName需要包含Psapi.h头文件,并链接到Psapi.lib

    #include <Psapi.h>
    #pragma comment (lib,"Psapi.lib")

    GetProcessImageFileName获取进程路径



    HANDLE hProcess=OpenProcess(PROCESS_QUERY_INFORMATION,FALSE,pe.th32ProcessID);
    if ( GetProcessImageFileName(hProcess,szFilePath,MAX_PATH)!=0 ){
    mystring strFilePath = CCommon::DosDevicePath2LogicalPath(szFilePath);

    }

    复制代码

    DosDevicePath2LogicalPath代码摘自:ms-help://MS.MSDNQTR.v80.chs/MS.MSDN.v80/MS.WIN32COM.v10.en/fileio/fs/obtaining_a_file_name_from_a_file_handle.htm

    mystring CCommon::DosDevicePath2LogicalPath(LPCTSTR lpszDosPath)
    {
    mystring strResult;

    // Translate path with device name to drive letters.
    TCHAR szTemp[MAX_PATH];
    szTemp[0] = '';

    if ( lpszDosPath==NULL || !GetLogicalDriveStrings(_countof(szTemp)-1, szTemp) ){
    return strResult;
    }

    TCHAR szName[MAX_PATH];
    TCHAR szDrive[3] = TEXT(" :");
    BOOL bFound = FALSE;
    TCHAR* p = szTemp;

    do{
    // Copy the drive letter to the template string
    *szDrive = *p;

    // Look up each device name
    if ( QueryDosDevice(szDrive, szName, _countof(szName)) ){
    UINT uNameLen = (UINT)_tcslen(szName);

    if (uNameLen < MAX_PATH) 
    {
    bFound = _tcsnicmp(lpszDosPath, szName, uNameLen) == 0;

    if ( bFound ){
    // Reconstruct pszFilename using szTemp
    // Replace device path with DOS path
    TCHAR szTempFile[MAX_PATH];
    _stprintf_s(szTempFile, TEXT("%s%s"), szDrive, lpszDosPath+uNameLen);
    strResult = szTempFile;
    }
    }
    }

    // Go to the next NULL character.
    while (*p++);
    } while (!bFound && *p); // end of string

    return strResult;
    }

    http://www.cnblogs.com/-clq/archive/2012/03/14/2395564.html

  • 相关阅读:
    开发流程之功能设计
    spring security之web应用安全
    feign架构原理解析
    负载均衡之ribbon
    服务发现之eureka
    JavaScript的内置对象
    JavaScript的流程控制语句以及函数
    JavaScript的基础语法及DOM元素和事件
    CSS的基础使用
    盒子模型
  • 原文地址:https://www.cnblogs.com/findumars/p/5812185.html
Copyright © 2011-2022 走看看