灰帽子python 学习记录 3

本篇的课题是附加进程。这个灰常坑爹,昨天没搞定,今天才搞好。


跟上篇产生进程不同,附加进程为附加到一个指定的进程,这样可以跳过启动步骤。


首先还是惯例,按书上的代码抄了一遍,写下一点理解吧:


步骤:

1,通过pid获取进程句柄,调用函数为OpenProcess

2,通过句柄附加进程,调用函数为DebugActiveProcess

3,通过WaitForDebugEvent捕获调试事件

4,通过ContinueDebugEvent继续执行

5,通过DebugActiveProcessStop分离出来,结束附加状态


今天要搞定的是1,2,5步。。。


首先获取进程句柄:

h_process = kernel32.OpenProcess(PROCESS_ALL_ACCESS,False,pid) 

然后附加:

kernel32.DebugActiveProcess(pid):

是不是看起来很简单。。。然而书里面把OpenProcess函数的第2和第3个参数搞反了顺序,所以一开始一直报错87号错误码,查msdn发现是参数错误。然后查OpenProcess文档发现了。。。

实验结果是附加qq后不分离的话qq会自动退出,chrome也差不多。而且每次获取到的handle值都不一样,好奇怪啊。


附错误码对照表:

https://msdn.microsoft.com/en-us/library/windows/desktop/ms681381(v=vs.85).aspx









  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值