驱动开发实现修改导入表注入dll

导入表注入dll其实就是给程序的导入表添加一个dll和相应函数,程序在被载入时,系统会自动加载该dll,从而实现dll注入。

我在驱动实现修改导入表的方法就是使用PsSetLoadImageNotifyRoutine函数创建回调,在回调中修改导入表。

修改导入表的过程如下:

1,申请一块内存,将原来的导入表和自己添加的项拷贝到这块内存。

2,修改pe头的导入表偏移,使其指向新导入表。

经过以上修改还不够,仍有部分程序不能正常运行,或不能成功注入dll。

原因如下:

1,程序有绑定导入表,就直接使用了,从而没有加载你的dll。解决办法就是清空绑定导入表。

2,有的编译器编译的程序没有IAT的偏移与大小,此时系统会检查导入表的范围,因为你申请的内存在pe范围之外,系统出错。所以解决方法就是自己填充IAT,使其指向原来的导入表位置。

3,另外,在修改pe时要去除写保护,此时需要修改先前模式。

代码见http://download.csdn.net/detail/uncia_me/9717160

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值