美文网首页
MFC逆向之查找控件消息处理函数

MFC逆向之查找控件消息处理函数

作者: jessica1123 | 来源:发表于2020-07-09 22:31 被阅读0次

前言:

最近碰到一个软件,想研究一下它的功能,奈何我对windows mfc 编程完全不懂,所以去网上找了文章学习了一下,下面记录我学习中的一些总结,主要供新手学习使用。

本文主要参考了这篇文章:
https://www.cnblogs.com/h2zZhou/p/10593168.html

请大家先参阅两篇文章,关于其中的知识点我可能不会细讲。
对于MFC逆向,我们主要想知道的是,当我们执行某个操作(点击某个按钮)的时候,程序会执行什么处理函数。
在mfc中,程序是使用消息机制来实现操作响应的,这个是消息映射表的代码:

struct AFX_MSGMAP{
    AFX_MSGMAP * pBaseMessageMap;
    AFX_MSGMAP_ENTRY * lpEntries;
}
struct AFX_MSGMAP_ENTRY{
    UINT nMessage;    //Windows Message
    UINT nCode        //Control code or WM_NOTIFY code
    UINT nID;         //control ID (or 0 for windows messages)
    UINT nLastID;     //used for entries specifying a range of control id's
    UINT nSig;        //signature type(action) or pointer to message 
    AFX_PMSG pfn;     //routine to call (or specical value)
}

具体含义请查看参考文章。
其中nID是一个关键的成员变量,它表示的是控件对应的ID,这个在一个程序中是独一无二的,而pfn是一个函数指针,它指向该控件对应的处理函数。

寻找消息处理函数的方法

  1. 利用idc脚本搜索AFX_MSGMAP
    这种方法可能搜索不到,它只能搜索到类似这种内存分布的


    image.png

但是在我实际的逆向过程中,发现有许多的消息映射表的内存分布是这样的:


image.png

这样子使用参考文章中的脚本就搜索不出来了,因此这种方法不太实用。

  1. 通过函数调用去查找,在参考文章中提到,是使用动态调试的方法寻找,函数路径如下:
    CWnd::WindowProc -> Cwnd::OnWndMsg(有时候IDA能直接识别这个函数) -> GetMessageMap
    关于这种方法,确实能找到消息映射表,但是有一点需要注意:在一个程序中可能有多个消息表,而这些表会被遍历初始化获取,所以需要在GetMessageMap函数处下断点,多次运行遍历来获得所有的消息映射表;

  2. 实际上还有一种更加简单的方法可以获取逆向找的消息函数,首先获取控件ID后,我们可以利用IDA的搜索功能,举个例子:
    我们首先使用ResourceHacker获取控件的ID:


    image.png

我们这里要找的控件ID是1021,它的十六进制是0x3fd,我们利用IDA Search菜单里的查找字节功能(Alt + B):


image.png

找到对应的所有序列之后,查看在.rdata段中的所有匹配项:


image.png

遍历这些项,能看到类似下图的结构:


image.png

这个结构的特点是前面一个函数的偏移地址,后面一个函数的偏移地址,类似这样的基本都是AFX_MSGMAP_ENTRY结构体,因此我们利用定义结构体的功能就可以把它转成消息映射表了:

struct AFX_MSGMAP_ENTRY{
    UINT nMessage;    //Windows Message
    UINT nCode        //Control code or WM_NOTIFY code
    UINT nID;         //control ID (or 0 for windows messages)
    UINT nLastID;     //used for entries specifying a range of control id's
    UINT nSig;        //signature type(action) or pointer to message 
    AFX_PMSG pfn;     //routine to call (or specical value)
}

我们在上一个函数偏移地址后的第一个数据处进行转换,具体怎么转换请看参考文章:


image.png

类似地,我们也可以把其他的数据都转换成这个结构,得到一个消息映射表,如下图:


image.png
其中红框内的就是我们要找的控件对应的消息处理函数。

总结

寻找某个控件的消息处理函数,推荐优先使用第三种方法。某些情况下,比如控件ID太小,比如为1的时候,如果直接搜索,可能会搜到过多的匹配项,我们可以使用第二种方法。

最后附上一个IDA使用技巧总结:
IDA Pro7.0使用技巧总结

相关文章

  • MFC逆向之查找控件消息处理函数

    前言: 最近碰到一个软件,想研究一下它的功能,奈何我对windows mfc 编程完全不懂,所以去网上找了文章学习...

  • MFC逆向-消息响应函数的定位

    layout: posttitle: MFC逆向-消息响应函数的定位categories: Reverse_Eng...

  • VC++(四)简单绘图

    MFC消息映射机制 MFC消息映射机制的具体实现方法是:在每个能接收和处理消息的类中,定义一个消息和消息函数静态对...

  • MFC的自定义控件之消息机制

    MFC消息机制 MFC是使用一种消息映射机制来处理消息,在应用程序框架中的表现就是一个消息与消息处理函数一一对应的...

  • MFC的消息机制

    1. 消息映射机制 1.1 消息映射机制的含义 MFC使用消息映射机制来处理消息,拥有一个消息与消息处理函数一一对...

  • MFC应用程序中处理消息的顺序

    MFC应用程序中处理消息的顺序 1.AfxWndProc() 该函数负责接收消息,找到消息所属的CWnd对象,然后...

  • duilib消息响应总结

    Duilib类似MFC的消息响应如下: 绑定消息响应函数: 映射到的函数: WindowImplBase也实现了一...

  • 10月11日C++学习总结

    今天讲了MFC框架对于六个网络事件的处理 当上述的网络事件发生时,MFC框架作何处理呢?按照Windows的消息...

  • MFC控件布局通用解决方案(转)

    MFC控件布局通用解决方案

  • MFC的自定义控件步骤

    MFC的自定义控件 开发环境 vs2015 步骤: 新建一个MFC 工程 在窗口中添加一个自定义控件Toolbox...

网友评论

      本文标题:MFC逆向之查找控件消息处理函数

      本文链接:https://www.haomeiwen.com/subject/rlveqktx.html