OpenProcess使用PROCESS_ALL_ACCESS返回ERROR_ACCESS_DENIED

原文地址

http://social.msdn.microsoft.com/Forums/en-US/vclanguage/thread/eeb93be6-872c-4028-b0ae-cd873e089825

 

Rajeesh... _

Rajeesh... _

Ness technologies

280 Points 5 0 0
Recent Achievements
First Helpful Vote Forums Replies I Forums Answerer I
Ness technologies

280 Points

   Answered
I just went through OpenProcess API in msdn, it says below for for PROCESS_ALL_ACCESS. I think this was the issue which you were facing.

Windows Server 2003 and Windows XP/2000:   The size of the PROCESS_ALL_ACCESS flag increased on Windows Server 2008 and Windows Vista. If an application compiled for Windows Server 2008 and Windows Vista is run on Windows Server 2003 or Windows XP/2000, the PROCESS_ALL_ACCESS flag is too large and the function specifying this flag fails with ERROR_ACCESS_DENIED. To avoid this problem, specify the minimum set of access rights required for the operation. If PROCESS_ALL_ACCESS must be used, set _WIN32_WINNT to the minimum operating system targeted by your application (for example,#define _WIN32_WINNT _WIN32_WINNT_WINXP). For more information, seeUsing the Windows Headers .

 

Windows Server 2008及Windows Vista上PROCESS_ALL_ACCESS的标志有所增加,如果应用程序编译时的target OS是Windows Server 2008或Windows Vista, 但却运行在Windows Server 2003或Windows XP/2000上,PROCESS_ALL_ACCESS太大,指定这个标志的函数会返回ERROR_ACCESS_DENIED错误。如果避免这个错误,指定操作所需的最小访问权限,而不是图省事指定PROCESS_ALL_ACCESS. 如果必须要用PROCESS_ALL_ACCESS, 要在程序中定义_WIN32_WINNT _WIN32_WINNT_WINXP

### 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.") ``` --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值