飘云阁

 找回密码
 加入我们

QQ登录

只需一步,快速开始

查看: 23508|回复: 38

[x64] 【新年礼物】Windows X64 DLL劫持工具 HiJackDll64 V1.1 Release

   关闭 [复制链接]

该用户从未签到

发表于 2015-2-12 15:11:10 | 显示全部楼层 |阅读模式
Windows X64 平台下的DLL劫持代码生成工具。

12.png


///////////////////////////////////////////////////////////

更新记录:
1.0.0.1008 2015.02.14
  Fix a Bug
  修复对中转输出表的处理

1.0.0.1007 2015.02.12
  Fix a Bug
  修复对导出数据的判断

1.0.0.1006 2015.01.09
  Fix a Bug
  添加软件使用说明功能

1.0.0.1005 2015.01.06
  支持了DLL导出数组的智能检测
  支持对X86 DLL的检测
  支持右键发送到,从命令行中解析DLL。

1.0.0.1003 2015.01.04
  加入对DLL中以序号导出函数的劫持
  应小Q要求,加入非系统DLL的相对劫持路径。

1.0.0.1001 2015.01.02
完成基本功能,生成 version.dll 项目OK。

///////////////////////////////////////////////////////////

下载链接: http://pan.baidu.com/s/1pJMCYH9 密码: p6wr

这个版本还是需要注册的,旨为打一下需要尝鲜的土豪,将来正式版还是会免费的。 O(∩_∩)O哈哈~

需要尝鲜的土豪,请购买附件后在PYGX64软件调试群 325016335中联系我算KEYFILE。

购买我算KEY.rar

125 Bytes, 阅读权限: 130, 下载次数: 9, 下载积分: 飘云币 -2 枚

售价: 300 枚飘云币  [记录]

评分

参与人数 6威望 +28 飘云币 +12 收起 理由
vitamin + 4 PYG有你更精彩!
一米阳光 + 4 感谢N大分享!1
飞天 + 4 + 4 PYG有你更精彩!
lucky_789 + 8 + 8 很给力!神奇越来越强大了
夜的静night + 4 赞一个!
bacsj118 + 4 赞一个!

查看全部评分

PYG19周年生日快乐!
  • TA的每日心情
    开心
    2015-8-2 16:07
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2015-2-12 21:16:11 | 显示全部楼层
    本帖最后由 F8LEFT 于 2015-2-12 23:03 编辑
    Nisy 发表于 2015-2-12 15:14
    已知问题,对于用depends22_x64查看到的DLL的导出函数中,Entry Point 这一项应该是RVA的,而对于显示 SHUN ...

    唉,慢慢编辑,不知道为啥一插入图片就自动退出编辑界面。。。是bug吧,求修复。
    64位的不懂,我就以32位的版本来说说我的看法。实验环境为Win7 64 位,文件所在目录为 C:\Windows\System32,测试文件为uxtheme.dll。
    ①导出函数
    首先,Dependency载入分析,得到的结果如下:


    与64位版本的一样,存在着其他dll的导出函数作为自己的导出函数。这里提供的信息有点少,我们再用另外一个工具来查询,这里小弟就用自己写的一个小工具,其他类似的也是可以的
    02.png
    可以看到,这里就显示出来该导出函数的RVA地址为 0x00011AE1,与隔壁的函数有着明显的位置差距。这是为什么呢,OD载入看一看。
    我这里OD载入的dll基地址为0x6F6B0000,后文用Base代替。
    这里先看10#函数,RVA为0x3BC15,OD跑到Base + 3BC15的地方看看,为:
    03.png
    一个非常正常的导出函数,RVA直指函数地址。
    于是,同理的看11#,也就是这个有问题的函数了。RVA为0x00011AE1,所以我们到 Base + 0x00011AE1的地方去。
    04.png
    代码有点怪,但是一时间也看不出有什么大问题。。。等等,这里是代码段吗?我们跑去数据窗口看一看这个地址。
    05.png

    晕了,原来这是一堆文字,表示SHUNIMPL的第190#函数。
    也就是说,这里的导出表有两种,一种是直指本身的导出函数的RVA,另外一种是指向其他函数的函数名的字符串。恩恩,原来如此原来如此。
    看到这里,相信懂的人已经知道了要怎么处理了吧。

    ②定位
    首先,取导出表地址,这里略去,我已经取得为 RVA 0x00011124
    接着,到Base + 0x00011124的位置取看,导出表结构为IMAGE_EXPORE_DIRECTORY,这里我们取其成员 AddressOfFunctions,偏移为 0x1c h,位置如下
    06.png
    看到指向的RVA为 0x0001114C,于是到Base + 0x0001114C中看,
    07.png 可以看到这里是一堆导出函数的入口RVA,每4个表示一个函数,如第一个DWORD 0x0003CC1F,就是序号为1的导出函数的RVA了。这里我们跳到第11个函数中去,图中我已经高亮显示了。RVA位置为 00011AE1,与我的小工具取到的是一样的,恩,相信已经知道了吧。就是这么简单。

    ③编程。居然还有这种的导出函数的?那么调用时会怎么样啊?
    这个用序号导出的函数不易调用,估计微软也不太想让我们用户来使用,所以从这里入手有点困难,不过,幸好,我们可以找到另外一个相似DLL,就是Version.dll了。Dependency载入,查一下导出函数
    11.png
    哈哈,VerLanguageNameA与VerLanguageNameW这两个函数竟然是来自Kernel32的,转个工具查得RVA分别为0x158B,0x15A5,赶紧去OD中看看
    09.png
    哈哈,相同的手法,相似的味儿。只是这里导出的是其他dll的名称函数,而不是序号函数。这样一来,就容易多了。我们写个动态地址加载的程序来看看是如何调用这种函数的。
    这里我选择加载VerLanguageNameA函数
    1. #include <windows.h>

    2. typedef DWORD (APIENTRY *pfnVerLanguageNameA)( _In_ DWORD wLang, _Out_writes_(cchLang) LPSTR szLang, _In_ DWORD cchLang );

    3. int main(_In_ int _Argc, _In_reads_(_Argc) _Pre_z_ char ** _Argv, _In_z_ char ** _Env)
    4. {
    5.         HMODULE hModule = LoadLibrary(TEXT("version.dll"));
    6.         pfnVerLanguageNameA NameA = (pfnVerLanguageNameA)GetProcAddress(hModule, "VerLanguageNameA");
    7.         CHAR Msg[MAX_PATH];
    8.         NameA(LANG_SYSTEM_DEFAULT, Msg, MAX_PATH);
    9.         return 0;
    10. }
    复制代码
    然后用OD载入,看一看是动态调用的地址为啥
    10.png
    哇咔咔,虽然加载的是Version.dll,GetProcAddress的是Version中的VerLanguangNameA,但是实际上得到的地址却是kernel32中的 VerLanguangNameA,原来系统没有这么笨,自动帮我们转过去了。所以,大家懂的,虽然dll中有其他dll中的导出函数定义,也可以调用,但是实际上调用到的地址还是其他dll中的导出函数地址。自己dll本身却是一点代码段都不含的。唉,既然这样,那么该如何弄才能达到这种效果啊。
    当然,这里可以按照一般Hook的思路,给出同名的函数,然后里面的跳转直接跳到有定义的dll中去,比如在写Version.dll中就可以 jmp [kernel32.VerLanguageNameA]这样汇编代码。何乐而不为呢?如果是序号呢?不怕,GetProcAddress同样可以通过序号来获取函数地址的。。。虽然微软并不建议这么做。。。(微软吐槽:弄成序号就是不想你调用了,干嘛非得强行调过去啊,要是版本一变,连序号都变了那么程序不就奔溃了?)怎么,怕出错,不妨试一下其他的方法。这里我以前写过version的Hook,其中的def文件定义文件是这样写的。
    1. LIBRARY version
    2. DESCRIPTION "A simple dll"
    3. EXPORTS
    4. GetFileVersionInfoA=Version_GetFileVersionInfoA @1
    5. GetFileVersionInfoByHandle=Version_GetFileVersionInfoByHandle @2            
    6. GetFileVersionInfoExW=Version_GetFileVersionInfoExW @3
    7. GetFileVersionInfoSizeA=Version_GetFileVersionInfoSizeA @4
    8. GetFileVersionInfoSizeExW=Version_GetFileVersionInfoSizeExW @5
    9. GetFileVersionInfoSizeW=Version_GetFileVersionInfoSizeW @6
    10. GetFileVersionInfoW=Version_GetFileVersionInfoW @7
    11. VerFindFileA=Version_VerFindFileA @8
    12. VerFindFileW=Version_VerFindFileW @9
    13. VerInstallFileA=Version_VerInstallFileA @10
    14. VerInstallFileW=Version_VerInstallFileW @11
    15. VerLanguageNameA @12
    16. VerLanguageNameW @13
    17. VerQueryValueA=Version_VerQueryValueA @14
    18. VerQueryValueW=Version_VerQueryValueW @15
    复制代码
    其中Version_##???一系列函数时我在主文件中有声明过的转接的函数,而那个12#与13#的函数VerLanguangNameA与VerLanguangNameW则是连声明都不给一个的。编译时居然就能自动识别为kernel32的函数了,厉害吧,估计是因为这两个函数已经在windows.h中有定义了,所以编译器就能自动识别了。惯例Dependency中看一下
    08.png
    恩恩,差别出来了,OD中看看, 12.png 与原dll的效果有着微妙的不同的一点还真是让人气愤,不过,算了,既然都能自动的跳过去就原谅了吧。{:soso_e112:}咪啪,拍键盘拍了这么久,手都累了,其他软件的进一步完善啊。

    点评

    我也看到了一份资料,这下这个BUG就可以搞定了。 标 题: 【原创】利用中转输出表制作HijackDll(附工具源码) 作 者: baixinye 时 间: 2012-08-05,16:48:45 链 接: http://bbs.pediy.com/showthread.php  详情 回复 发表于 2015-2-13 17:33

    评分

    参与人数 4威望 +56 飘云币 +52 收起 理由
    夜的静night + 4 很给力!
    pdjfx + 8 + 8 赞一个!
    Nisy + 40 + 40 感谢帮忙分析
    飞天 + 4 + 4 赞一个!

    查看全部评分

    PYG19周年生日快乐!
    回复 支持 1 反对 0

    使用道具 举报

    该用户从未签到

     楼主| 发表于 2015-2-12 15:14:25 | 显示全部楼层
    已知问题,对于用depends22_x64查看到的DLL的导出函数中,Entry Point 这一项应该是RVA的,而对于显示 SHUNIMPL.# 这样的的含义是?因为我发现我这边获取不到该导出函数。如果您了解这个解决方案请单独联系我,可以免费获取KEYFILE一枚。

    // 貌似是去调用 C:\Windows\System32\shunimpl.dll 的导出接口,但是这个信息是从哪里得来的呢?又如何来获取到真正的函数入口。

    11.png

    点评

    64位的不懂,我就以32位的版本来说说我的看法。实验环境为Win7 64 位,文件所在目录为 C:\Windows\System32,测试文件为uxtheme.dll。 首先,Dependency载入分析,得到的结果如下: [attachimg]60124[/attac  详情 回复 发表于 2015-2-12 21:16
    PYG19周年生日快乐!
  • TA的每日心情
    无聊
    2024-7-22 05:31
  • 签到天数: 1076 天

    [LV.10]以坛为家III

    发表于 2015-2-12 16:16:36 | 显示全部楼层
    卖不起的
    看看...
    PYG19周年生日快乐!
  • TA的每日心情
    无聊
    2023-4-16 17:28
  • 签到天数: 29 天

    [LV.4]偶尔看看III

    发表于 2015-2-12 16:18:51 | 显示全部楼层

    卖不起的看看吧
    PYG19周年生日快乐!
  • TA的每日心情

    2024-8-12 20:55
  • 签到天数: 219 天

    [LV.7]常住居民III

    发表于 2015-2-12 17:19:28 | 显示全部楼层
    我擦  潜水这么多年都买不起个附件 伤不起啊  求回血
    PYG19周年生日快乐!
  • TA的每日心情
    郁闷
    前天 09:16
  • 签到天数: 2422 天

    [LV.Master]伴坛终老

    发表于 2015-2-12 18:28:17 | 显示全部楼层
    {:soso_e105:}
    好强大,好想要
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2024-2-21 19:57
  • 签到天数: 77 天

    [LV.6]常住居民II

    发表于 2015-2-12 18:46:39 | 显示全部楼层
    都穷的掉渣了!
    PYG19周年生日快乐!
  • TA的每日心情
    奋斗
    2017-3-10 20:59
  • 签到天数: 243 天

    [LV.8]以坛为家I

    发表于 2015-2-13 11:23:02 | 显示全部楼层
    支持一下了,还不会用,等待正式免费版
    PYG19周年生日快乐!
  • TA的每日心情
    开心
    2024-11-29 12:36
  • 签到天数: 52 天

    [LV.5]常住居民I

    发表于 2015-2-13 14:37:48 | 显示全部楼层
    东西是好,可惜腰里没铜啊。
    PYG19周年生日快乐!
    您需要登录后才可以回帖 登录 | 加入我们

    本版积分规则

    快速回复 返回顶部 返回列表