【转】XP下OpenProcess( PROCESS_ALL_ACCESS...失败

本文介绍了解决XP下OpenProcess(PROCESS_ALL_ACCESS...失败的方法。通过在程序起始处调用AddPrivilege(SE_DEBUG_NAME),成功解决了单独运行时无法打开进程的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自http://hi.baidu.com/1981633/item/04c78cceb3cf563399b4983b

XP下OpenProcess( PROCESS_ALL_ACCESS...失败

在编译器下调试时可以打开进程,单独运行时不行。代码来自网上。
解决方法:

int   AddPrivilege(const   char   *Name) 

 HANDLE   hToken; 
 TOKEN_PRIVILEGES   tp; 
 LUID   Luid;

 if   (!OpenProcessToken(GetCurrentProcess(), 
  TOKEN_ADJUST_PRIVILEGES|TOKEN_QUERY, 
  &hToken)) 
 { 
#ifdef   _DEBUG 
  printf( "OpenProcessToken   error.\n "); 
#endif 
  return   1; 
 }

 if   (!LookupPrivilegeValue(NULL,Name,&Luid)) 
 { 
#ifdef   _DEBUG 
  printf( "LookupPrivilegeValue   error.\n "); 
#endif 
  return   1; 
 }

 tp.PrivilegeCount   =   1; 
 tp.Privileges[0].Attributes   =   SE_PRIVILEGE_ENABLED; 
 tp.Privileges[0].Luid   =   Luid;

 if   (!AdjustTokenPrivileges(hToken, 
  0, 
  &tp, 
  sizeof(TOKEN_PRIVILEGES), 
  NULL, 
  NULL)) 
 { 
#ifdef   _DEBUG 
  printf( "AdjustTokenPrivileges   error.\n "); 
#endif 
  return   1; 
 }

 return   0; 



在程序起始处调用 AddPrivilege(SE_DEBUG_NAME);即可。

转载于:https://www.cnblogs.com/yibinpan/archive/2013/05/29/3105285.html

### ctypes.windll.kernel32.OpenProcess 参数详解及功能说明 `ctypes.windll.kernel32.OpenProcess` 是 Python 中用于调用 Windows API `OpenProcess` 函数的方法。此函数的主要目的是打开一个已存在的进程对象并返回该进程的句柄,允许开发者对该进程进行进一步的操作。 以下是 `OpenProcess` 的参数详解: #### 1. **dwDesiredAccess** - 类型:DWORD - 描述:指定所需的访问权限,这些权限决定了可以对目标进程执行哪些操作。常见的值包括: - `PROCESS_ALL_ACCESS`: 完全控制权限。 - `PROCESS_QUERY_INFORMATION`: 查询进程的信息。 - `PROCESS_VM_READ`: 读取进程的虚拟内存。 - `PROCESS_TERMINATE`: 终止进程的能力。 - 这些常量可以通过按位 OR (`|`) 结合使用多个权限[^4]。 #### 2. **bInheritHandle** - 类型:BOOL - 描述:指示所获得的进程句柄是否可以被子进程继承。如果设置为 `True`(非零),则新创建的子进程可以从父进程中继承这个句柄;如果是 `False`(零),则不可继承。 #### 3. **dwProcessId** - 类型:DWORD - 描述:要打开的目标进程的 ID (PID)。这是唯一标识某个特定进程的关键信息。通常通过其他 WinAPI 调用(如 `GetWindowThreadProcessId`)来获取 PID[^2]。 #### 返回值 成功时返回一个有效的 `HANDLE` 值,代表目标进程的对象句柄;失败时返回 `None` 或者无效句柄,并可通过 `GetLastError()` 获取具体错误原因。 --- ### 功能说明 `OpenProcess` 主要用于以下场景: - 打开现有进程以监控其状态或行为。 - 对另一个进程实施某些管理动作,比如终止它、修改它的优先级或者读/写其内存区域。 - 在高级应用场合下配合 token 操作完成权限提升等功能[^5]。 需要注意的是,在实际开发过程中应当谨慎处理此类低层 API 调用,因为不当使用可能导致系统不稳定甚至崩溃[^3]。 ```python import ctypes def open_process(pid, desired_access=0x1F0FFF, inherit_handle=False): """ 使用 OpenProcess 打开指定 PID 的进程 :param pid: 目标进程的 PID :param desired_access: 请求的访问权限,默认 PROCESS_ALL_ACCESS :param inherit_handle: 是否允许继承句柄 :return: 成功返回有效句柄,失败返回 None """ kernel32 = ctypes.windll.kernel32 process_handle = kernel32.OpenProcess(desired_access, int(inherit_handle), pid) if not process_handle: error_code = kernel32.GetLastError() print(f"Failed to open process with PID {pid}. Error Code: {error_code}") return None return process_handle if __name__ == "__main__": target_pid = 1234 # 替换为目标进程的真实 PID handle = open_process(target_pid) if handle: print("Successfully opened the process.") ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值