[逆向] x64dbg / od 设置消息断点

背景

很多时候在我们不知道目标程序调用了哪些 api 时,需要使用消息断点粗略的定位关键代码位置。比如在游戏里点击一次鼠标,可以根据这个消息向下跟踪点击完鼠标后游戏执行的逻辑。

方法

一个简单的消息循环是这样的 :

while( GetMessage(&msg,NULL,0,0) )     
{
    TranslateMessage(&msg);            //将 WM_XXXKEYXXX 消息翻译为 WM_CHAR 消息
    DispatchMessage(&msg);             //传递消息到窗口过程
}   

TranslateMessage

BOOL TranslateMessage(
  const MSG *lpMsg
);

typedef struct tagMSG {
  HWND   hwnd;
  UINT   message;					// 消息代码
  WPARAM wParam;
  LPARAM lParam;
  DWORD  time;
  POINT  pt;
  DWORD  lPrivate;
} MSG, *PMSG, *NPMSG, *LPMSG;

由此可知,只要对 message 这个成员变量设置条件断点就可以实现所谓的消息断点 。

32位:

[[esp+0x4]+0x4]==0x1234			(这里的 1234 就是你想拦截的消息代码)

64位:

[[rcx]+0x8]==0x1234			(HANDLE 是 void* 类型,所以 64 位下偏移是 0x8
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值