首页
社区
课程
招聘
[旧帖] [求助]想改MFC程序的窗口,让它一开始就最大化。 0.00雪花
发表于: 2009-7-31 20:02 1924

[旧帖] [求助]想改MFC程序的窗口,让它一开始就最大化。 0.00雪花

2009-7-31 20:02
1924
该程序是个绿色版,只有一个exe和三个DLL:
C:\CAD\CADe_SIMU.exe
C:\CAD\MFC42D.DLL
C:\CAD\MFCO42D.DLL
C:\CAD\MSVCRTD.DLL
用ollydbg调试,输入函数只是显示:
006AE05C  .idata    输入        MFC42D.#1019
006AE164  .idata    输入        MFC42D.#1033
之类的,没法其知道是在哪里确定的窗口样式。
下断CreateWindowExa,回溯

5F42D4F5 >/$  55            push    ebp
5F42D4F6  |.  8BEC          mov     ebp, esp
5F42D4F8  |.  83EC 38       sub     esp, 38
5F42D4FB  |.  53            push    ebx
5F42D4FC  |.  56            push    esi
5F42D4FD  |.  57            push    edi
5F42D4FE  |.  894D C8       mov     dword ptr [ebp-38], ecx
5F42D501  |.  8B45 08       mov     eax, dword ptr [ebp+8]
5F42D504  |.  8945 F8       mov     dword ptr [ebp-8], eax
5F42D507  |.  8B4D 0C       mov     ecx, dword ptr [ebp+C]
5F42D50A  |.  894D F4       mov     dword ptr [ebp-C], ecx
5F42D50D  |.  8B55 10       mov     edx, dword ptr [ebp+10]
5F42D510  |.  8955 F0       mov     dword ptr [ebp-10], edx
5F42D513  |.  8B45 14       mov     eax, dword ptr [ebp+14]
5F42D516  |.  8945 EC       mov     dword ptr [ebp-14], eax
5F42D519  |.  8B4D 18       mov     ecx, dword ptr [ebp+18]
5F42D51C  |.  894D E8       mov     dword ptr [ebp-18], ecx
5F42D51F  |.  8B55 1C       mov     edx, dword ptr [ebp+1C]
5F42D522  |.  8955 E4       mov     dword ptr [ebp-1C], edx
5F42D525  |.  8B45 20       mov     eax, dword ptr [ebp+20]
5F42D528  |.  8945 E0       mov     dword ptr [ebp-20], eax
5F42D52B  |.  8B4D 24       mov     ecx, dword ptr [ebp+24]
5F42D52E  |.  894D DC       mov     dword ptr [ebp-24], ecx
5F42D531  |.  8B55 28       mov     edx, dword ptr [ebp+28]
5F42D534  |.  8955 D8       mov     dword ptr [ebp-28], edx
5F42D537  |.  8B45 2C       mov     eax, dword ptr [ebp+2C]
5F42D53A  |.  8945 D4       mov     dword ptr [ebp-2C], eax
5F42D53D  |.  E8 1BDB0400   call    #1096
5F42D542  |.  8945 D0       mov     dword ptr [ebp-30], eax
5F42D545  |.  8B4D 30       mov     ecx, dword ptr [ebp+30]
5F42D548  |.  894D CC       mov     dword ptr [ebp-34], ecx
5F42D54B  |.  8D55 CC       lea     edx, dword ptr [ebp-34]
5F42D54E  |.  52            push    edx
5F42D54F  |.  8B45 C8       mov     eax, dword ptr [ebp-38]
5F42D552  |.  8B10          mov     edx, dword ptr [eax]
5F42D554  |.  8B4D C8       mov     ecx, dword ptr [ebp-38]
5F42D557  |.  FF52 64       call    dword ptr [edx+64]
5F42D55A  |.  85C0          test    eax, eax
5F42D55C  |.  75 15         jnz     short 5F42D573
5F42D55E  |.  8B45 C8       mov     eax, dword ptr [ebp-38]
5F42D561  |.  8B10          mov     edx, dword ptr [eax]
5F42D563  |.  8B4D C8       mov     ecx, dword ptr [ebp-38]
5F42D566  |.  FF92 AC000000 call    dword ptr [edx+AC]
5F42D56C  |.  33C0          xor     eax, eax
5F42D56E  |.  E9 A7000000   jmp     5F42D61A
5F42D573  |>  8B45 C8       mov     eax, dword ptr [ebp-38]
5F42D576  |.  50            push    eax                              ; /Arg1
5F42D577  |.  E8 FAFDFFFF   call    #1113                            ; \#1113
5F42D57C  |.  8B4D CC       mov     ecx, dword ptr [ebp-34]
5F42D57F  |.  51            push    ecx                              ; /lParam
5F42D580  |.  8B55 D0       mov     edx, dword ptr [ebp-30]          ; |
5F42D583  |.  52            push    edx                              ; |hInst
5F42D584  |.  8B45 D4       mov     eax, dword ptr [ebp-2C]          ; |
5F42D587  |.  50            push    eax                              ; |hMenu
5F42D588  |.  8B4D D8       mov     ecx, dword ptr [ebp-28]          ; |
5F42D58B  |.  51            push    ecx                              ; |hParent
5F42D58C  |.  8B55 DC       mov     edx, dword ptr [ebp-24]          ; |
5F42D58F  |.  52            push    edx                              ; |Height
5F42D590  |.  8B45 E0       mov     eax, dword ptr [ebp-20]          ; |
5F42D593  |.  50            push    eax                              ; |Width
5F42D594  |.  8B4D E4       mov     ecx, dword ptr [ebp-1C]          ; |
5F42D597  |.  51            push    ecx                              ; |Y
5F42D598  |.  8B55 E8       mov     edx, dword ptr [ebp-18]          ; |
5F42D59B  |.  52            push    edx                              ; |X
5F42D59C  |.  8B45 EC       mov     eax, dword ptr [ebp-14]          ; |
5F42D59F  |.  50            push    eax                              ; |Style
5F42D5A0  |.  8B4D F0       mov     ecx, dword ptr [ebp-10]          ; |
5F42D5A3  |.  51            push    ecx                              ; |WindowName
5F42D5A4  |.  8B55 F4       mov     edx, dword ptr [ebp-C]           ; |
5F42D5A7  |.  52            push    edx                              ; |Class
5F42D5A8  |.  8B45 F8       mov     eax, dword ptr [ebp-8]           ; |
5F42D5AB  |.  50            push    eax                              ; |ExtStyle
5F42D5AC  |.  FF15 F4B84A5F call    dword ptr [<&USER32.CreateWindow>; \CreateWindowExA

不知道是不是在
5F42D59C  |.  8B45 EC       mov     eax, dword ptr [ebp-14]          ; |
5F42D59F  |.  50            push    eax                              ; |Style
确定style的值,这时候是
eax=00CF8000
MFC42D.#1658+0AA
但是最后形成的窗口样式值却是:54CFC000
不知道最后在哪里改变了?

[招生]科锐逆向工程师培训(2024年11月15日实地,远程教学同时开班, 第51期)

收藏
免费 0
支持
分享
最新回复 (4)
雪    币: 20
活跃值: (13)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
2
不是很熟悉Win32编程,我想应该在ShowWindow函数里吧.
有隐藏、最大、最小之类的参数
2009-7-31 20:11
0
雪    币: 191
活跃值: (345)
能力值: ( LV9,RANK:450 )
在线值:
发帖
回帖
粉丝
3
如果你是为了分析,那就看看代码吧,如果不是,而是只为了使用方便,那没必要修改代码了

看图

上传的附件:
2009-7-31 21:52
0
雪    币: 83
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
4
谢谢了,还知道有这种办法。
不过他是多文档窗口,这个能实现外面窗口最大化了,里面的还没改变。还得在探索一下,呵呵。

关于MFC42函数显示的问题,找到办法了,就是在ollydbg的LIB文件夹里加入MFC42D.lib即可,然后选择“调试”>“选择导入库”即可。
MFC42D.lib在VC的安装文件夹里有,也可以网上下载:
http://apuntes.danielcastelao.org/software/programacion/VisualC/VC98/MFC/LIB/
2009-7-31 22:09
0
雪    币: 183
活跃值: (1193)
能力值: ( LV3,RANK:30 )
在线值:
发帖
回帖
粉丝
5
呵呵  以前还不知道有三楼的这种方法
2009-8-2 15:07
0
游客
登录 | 注册 方可回帖
返回
//