DuiLib逆向分析の按钮事件定位
DuiLib逆向分析の按钮事件定位
0x00 前言
记录自己学习Duilib逆向分析的笔记。
DuiLib介绍
DuiLib官方介绍,Duilib是一个Windows下免费开源的DirectUI界面库,由于简约易扩展的设计以及稳定高效的实现被各大互联网公司普遍接受,广泛应用于包括IM、视频客户端、股票行情软件、导航软件、手机辅助软件、安全软件等多个行业的众多pc客户端软件。Duilib还在不断的发展中,在文档、例子、动画、渲染引擎等多个方面将持续改进。
DirectUI介绍,直接在父窗口上绘图,构建易于扩展的界面。(DirectUI意为直接在父窗口上绘图(Paint on parent dc directly)。即子窗口不以窗口句柄 的形式创建(windowless),只是逻辑上的窗口,绘制在父窗口之上。)
Duilib是一个自绘控件界面库,可以很方便的构建高效,绚丽的,非常易于扩展的界面。
国外如微软,国内如腾讯,百度等公司的客户端产品多采用这种方式来组织界面,从而很好的将界面和逻辑分离,同时易于实现各种超炫的界面效果如换色,换肤,透明等。
DuiLib安装
安装DuiLib推荐用C++库管理器vcpkg
来安装,这东西我感觉类似Python的pip
。可以很方便的安装管理第三方库
。
vcpkg官方安装教程,安装vcpkg非常简单,就如下几条命令就搞定:
1 | git clone https://github.com/microsoft/vcpkg |
安装DuiLib库:
1 | vcpkg install DuiLib #安装DuiLib库 |
DuiLib Hello,World!
装好了库后,我们来写第一个DuiLib程序,经典的Hello,World!
1 | //DuiLib库头文件 |
1 | int __stdcall wWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPWSTR lpCmdLine, int nCmdShow) |
duilib.xml 界面布局文件
1 |
|
编译生成后的界面如下,并且点击按钮后触发了事件:
Duilib逆向分析之定位按钮事件
碎碎念
所以我觉得做逆向开发,不能盲目的一开始就去看OD,去IDA F5反编译,而是应该擅长利用搜索引擎去学习了解相关:框架、库、模型、开发等知识,有了这些知识后逆向就如鱼得水。
第一步:获取xml布局文件
首先切入点是从duilib.xml
文件开始,所以我们在逆向Duilib相关程序时候应该先拿到他的布局文件。
而在我们的demo中duilib.xml是在本地的,而在源码中可以看到builder.Create
来加载使用duilib.xml
。
如果xml在本地的话则很简单直接找到路径即可,但是常规逆向分析中基本都是在内存中的,那这种要如何获取到他的xml布局文件呢?
思路还是一样,先定位到这个builder.Create
函数,然后跟进去一步步调试,看堆栈信息,看经过哪一句汇编代码或Call后出现xml内容。
第二步:按钮事件分金点穴
当我们拿到布局后,找到对应按钮的名称,例子中的按钮对应的名称是Hello_btn
,然后去调试软件中搜索相关字符串Hello_btn
。
并且下上断点。
当我们点击按钮后,成功的断到如下位置:
断点断到后,查看上下文中的汇编就已经很明显了,在je下面 (je那一句是判断当前btn按钮事件是否是Hello_btn
的按钮事件),对应的源码就是:
1 | if(msg.pSender->GetName() == _T("Hello_btn")) |
感谢观看我的笔记,如有问题请指出谢谢。
逆向、PWN学习交流