python进程提权与检测进程调用所有模块

这篇博客介绍了如何使用Python结合ctypes和win32api库扫描Windows系统的进程,并针对权限不足的问题,通过调用C编写的DLL实现进程提权,以获取其他进程的模块信息。文章详细阐述了提权过程及遇到的问题,并展示了部分代码示例。
摘要由CSDN通过智能技术生成

前段时间闲着没事,做查进程的,ring0层面的方法太多代码也太多,头脑发热写了个python的扫进程,调用的主要是win32api。

木有这个库的可以去网上下下来装一装,挺强大。

主要用了:

ctypes.windll.kernel32.CreateToolhelp32Snapshot

ctypes.windll.kernel32.Process32First

ctypes.windll.kernel32.Process32Next

win32api.OpenProcess

win32process.EnumProcessModules

不知道的可以查一查。

但是光是这些是不够的,直接扫进程的话会因为权限不够导致很多进程访问不能,不能利用win32process.EnumProcessModules扫描进程调用的所有模块。所以要对进程本身进行提权,赋予进程本身访问其他进程的权限。

请大家看一看没有提权的枚举进程调用模块的情况:

可以看到虽然能枚举到进程但是无法枚举进程调用的模块。


这个请参考:http://blog.sina.com.cn/s/blog_77fbf10501017hoe.html

利用

OpenProcessToken

赋予进程扫其他进程的令牌权限。


问题又来了,python貌似掉不到这个函数。或者能够调用但是我不会到方法。

所以我用c写了个dll,然后用python来调用这个函数:


procup.h:

extern "C" _declspec(dllexport) bool e
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值