下GetWindowTextA这个断点可以找到关键代码的位置,但是算法太复杂,研究不了,具体代码位置:
[Asm] 纯文本查看 复制代码 00430791 /$ 55 push ebp
00430792 |. 8BEC mov ebp,esp
00430794 |. 83EC 20 sub esp,0x20
00430797 |. 56 push esi
00430798 |. 8B75 08 mov esi,[arg.1]
0043079B |. 57 push edi
0043079C |. 8BCE mov ecx,esi
0043079E |. FF75 0C push [arg.2]
004307A1 |. E8 CBFEFFFF call PB.00430671
004307A6 |. 833E 00 cmp dword ptr ds:[esi],0x0
004307A9 |. 8BF8 mov edi,eax
004307AB |. 74 35 je short PB.004307E2
004307AD |. 8D45 E0 lea eax,[local.8]
004307B0 |. 6A 20 push 0x20 ; /Count = 20 (32.)
004307B2 |. 50 push eax ; |Buffer = 0018F4C8
004307B3 |. 57 push edi ; |hWnd = 0018F4C8
004307B4 |. FF15 30254400 call dword ptr ds:[<&USER32.GetWindowTex>; \GetWindowTextA
004307BA |. 8D45 18 lea eax,[arg.5]
004307BD |. 50 push eax
004307BE |. 8D45 E0 lea eax,[local.8]
004307C1 |. FF75 10 push [arg.3]
004307C4 |. 50 push eax
004307C5 |. E8 22FFFFFF call PB.004306EC
004307CA |. 85C0 test eax,eax
004307CC 75 2F jnz short PB.004307FD
004307CE |. 6A FF push -0x1
004307D0 |. 50 push eax
004307D1 |. FF75 14 push [arg.4]
004307D4 |. E8 02FCFFFF call PB.004303DB
004307D9 |. 8BCE mov ecx,esi
004307DB |. E8 D7FEFFFF call PB.004306B7
|