最近在学习dll劫持,一些原理上的东西参见 https://payloads.online/archivers/2018-06-09/1,我这里具体写下发现wegame dll劫持的步骤。
首先是准备工作,即两款工具:
pressmonitor:
https://download.sysinternals.com/files/ProcessMonitor.zip
dll_hijacker.py:
https://raw.githubusercontent.com/zhaoed/DLL_Hijacker/master/DLL_Hijacker.py
下面是正式步骤:
process monitor的filter规则如图,即仅显示tgp_daemon进程加载dll过程。
data:image/s3,"s3://crabby-images/d0114/d011451b8426ad24fc026f3e0c2906812fbec021" alt=""
可以看到进程先在其安装目录E:\Wegame\没有找到winmmase.dll,然后再c:\windows\syswow64中找到了该dll,所以我们可以直接在E:\Wegame放入我们自定义的同名dll,就达到了dll劫持的效果。但是为了不影响原程序的运行,我们需要让程序先执行了我们的dll,再执行原本的dll。这里就用到了dll_hijacker.py
data:image/s3,"s3://crabby-images/85c19/85c1942565c19d72543340a9aa1b62f09d2e7e3c" alt=""
data:image/s3,"s3://crabby-images/bf1c9/bf1c96f9a434bffe39b0fa92e7b540e366563ef7" alt=""
data:image/s3,"s3://crabby-images/d652e/d652ef9c65501296466b6800445b54f5a1ba600b" alt=""
将生成的cpp内容放入vc的dll工程中,并修改几个地方:
1.vc6环境需添加#include "stdafx.h"
2将Hijack函数改为自己想执行的操作,systemm函数需要#include <stdlib.h>
data:image/s3,"s3://crabby-images/dee40/dee40db31cde19de34ba1587f249a47ee0bd108d" alt=""
3.修改需要调用的原版dll名,并放入E:\Wegame\,注意需要把原dll的mui文件一起放入,否则将会报错
data:image/s3,"s3://crabby-images/ae9cb/ae9cb7618638a0403ef19ee52f7b29e9402fd2c6" alt=""
data:image/s3,"s3://crabby-images/e2a39/e2a39a60ef62b674fe7e55fa61597694fdbd3a10" alt=""
效果:
data:image/s3,"s3://crabby-images/5d003/5d003e6caa4de477ca2e06de5a558f96195d70b0" alt=""
网友评论