鱼C论坛

 找回密码
 立即注册
查看: 2678|回复: 13

win32汇编中的一个问题

[复制链接]
回帖奖励 7 鱼币 回复本帖可获得 1 鱼币奖励! 每人限 1 次(中奖概率 10%)
发表于 2014-10-11 19:54:05 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x


代码如下:
.const
szMyClass            db'my class',0
szName               db'我的窗口',0
szLpName           db'欢迎来到我的窗口',0
szButton             db'button',0
szbuttontext      db'鱼c',0
szopen               db'open',0
szwenjian           db'http://www.fishc.com'


......
invoke            DrawText,@hdc,addr szLpName ,-1,addr @strect,\
                      DT_SINGLELINE or DT_CENTER or DT_VCENTER
.......

invoke            CreateWindowEx,NULL,offset szButton,offset szbuttontext,WS_CHILD or WS_VISIBLE,\
                      200,250,88,22,hWnd,1,hIstance,NULL

两个问题,第一个,既然szLpName 是全局变量,为什么这里用addr 不用offset
第二个问题 :createwindowex  这个函数中,offset szbutton  这里的变量 szbutton中的内容为什么一定要button ,换成别的字符串就导致这个按钮出不来?

求解决,谢谢

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-10-12 02:02:17 | 显示全部楼层
第一个 : addr 是invoke 专用的,和lea一样的,但lea不能用在invoke上。
这里用offset应该可以的,你试下
offset和lea的区别在于offset是编译的时候就是地址了,比如40000000.而lea是在程序运行的时候才取实际地址的,编译的时候只是用符号之类的东西代替。注入之类搞小动作的很多时候都要用到lea

第二个 : createwindowex  这个函数的前面还有一个注册函数的,你注册函数注册的类名就是button了,你后面createwindowex的参数用别的类名当然不行,你把注册函数所需参数的那个结构的类名改成一致的就可以了。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-12 08:45:25 | 显示全部楼层
dAb 发表于 2014-10-12 02:02
第一个 : addr 是invoke 专用的,和lea一样的,但lea不能用在invoke上。
这里用offset应该可以的,你试下 ...

我给您看下完整的代码:
.386
.model flat,stdcall
option casemap:none

include                windows.inc
include                user32.inc
includelib                        user32.lib
include                kernel32.inc
includelib                         kernel32.lib
include                gdi32.inc
includelib                        gdi32.lib
include                shell32.inc
includelib                         shell32.lib

.data?
hIstance                dd        ?
hMainIstance        dd        ?

.const

szMyClass                db'my class',0
szName                db'我的窗口',0
szLpName                db'欢迎来到我的窗口',0
szButton                db'button',0
szbuttontext        db'鱼c',0
szopen                db'open',0
szwenjian                db'http://www.fishc.com'

.code

_mainproc                 proc  uses ebx edi esi hWnd,uMsg,wParam,lParam
                                local @stps:PAINTSTRUCT
                                local @strect:RECT
                                local @hdc
mov                                eax,uMsg
                                .if eax == WM_PAINT
invoke                        BeginPaint,hWnd,addr @stps
mov                         @hdc,eax
invoke                        GetClientRect,hWnd,addr @strect
invoke                        DrawText,@hdc,addr szLpName ,-1,addr @strect,\
                        DT_SINGLELINE or DT_CENTER or DT_VCENTER
                               
invoke                        EndPaint,hWnd,addr @stps


                        .elseif        eax ==WM_COMMAND
mov                         eax,wParam
                        .if eax == IDOK
invoke                        ShellExecute,NULL,offset szopen,offset  
szwenjian,NULL,NULL,SW_SHOWNORMAL

                        .endif
                               
                        .elseif eax == WM_CREATE
invoke                        CreateWindowEx,NULL,offset szButton,offset szbuttontext,WS_CHILD or WS_VISIBLE,\
                        200,250,88,22,hWnd,1,hIstance,NULL
                        .elseif        eax ==        WM_CLOSE
invoke                        DestroyWindow,hMainIstance
invoke                        PostQuitMessage,NULL
                        .else
invoke                        DefWindowProc,hWnd,uMsg,wParam,lParam
ret
                        .endif
xor        eax,eax
ret
_mainproc                endp
                       
_winmain                 proc

local                        @stWndClass:WNDCLASSEX
local                        @stMsg:MSG
invoke                         GetModuleHandle,NULL
mov                        hIstance,eax
invoke                        RtlZeroMemory,addr @stWndClass,sizeof @stWndClass
invoke                         LoadCursor,0,IDC_ARROW
mov                        @stWndClass.hCursor,eax
push                        hIstance
pop                                @stWndClass.hInstance
mov                                @stWndClass.cbSize,sizeof WNDCLASSEX
mov                                @stWndClass.style,CS_HREDRAW or CS_VREDRAW       
mov                                @stWndClass.hbrBackground,COLOR_WINDOW + 1
mov                                @stWndClass.lpszClassName,offset szMyClass
mov                                @stWndClass.lpfnWndProc,offset _mainproc
invoke                         RegisterClassEx,addr @stWndClass
invoke                        CreateWindowEx,WS_EX_CLIENTEDGE,offset szMyClass,\
                        offset szName,WS_OVERLAPPEDWINDOW,100,100,600,400,\
                                NULL,NULL,hIstance,NULL
mov                                hMainIstance,eax
invoke                        ShowWindow,hMainIstance,SW_SHOWNORMAL       
invoke                        UpdateWindow,hMainIstance

.while                         TRUE
invoke                        GetMessage,addr @stMsg,NULL,0,0
.break                         .if  eax == 0

invoke                        TranslateMessage,addr @stMsg
invoke                        DispatchMessage,addr @stMsg
.endw
ret
_winmain                endp
                               
start:
call                          _winmain
invoke                        ExitProcess,NULL
end start
我格式修改了下,但是没完全弄好,请帮我在看下。第二个问题。谢谢

评分

参与人数 1荣誉 +8 鱼币 +8 贡献 +2 收起 理由
小靚同学Leon + 8 + 8 + 2 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-10-12 09:54:10 | 显示全部楼层

回帖奖励 +1 鱼币

本帖最后由 avatar10010 于 2014-10-12 09:59 编辑
aa05001 发表于 2014-10-12 08:45
我给您看下完整的代码:
.386
.model flat,stdcall

问题1:
addr也可以用于全局变量(此时编译器还是将addr转换成offset,楼主可以反汇编看看就知道了),但为了防止出错,建议将addr用于局部变量而offset用于全局变量
问题2:
你把szbutton的值改为edit,dialog都是可以的,应为这是windows内部定义好的窗口类,如果要想自定义窗口类的话,要在创建窗口之前先注册窗口类,可参考RegisterClass函数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2014-10-12 11:29:40 | 显示全部楼层
avatar10010 发表于 2014-10-12 09:54
问题1:
addr也可以用于全局变量(此时编译器还是将addr转换成offset,楼主可以反汇编看看就知道了), ...

很感谢,你给的答案,我看了下,确实可以。谢谢你。又增长知识了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2014-11-1 05:18:33 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-4-17 02:09:54 | 显示全部楼层
顶一下
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-4-17 09:58:23 | 显示全部楼层
路过ING
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-4-18 09:42:52 | 显示全部楼层
支持lz
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-2 16:13:59 | 显示全部楼层
这个好、!!额额,支持楼主
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-3 21:45:38 | 显示全部楼层
aa05001 发表于 2014-10-12 11:29
很感谢,你给的答案,我看了下,确实可以。谢谢你。又增长知识了。

感谢分享!!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-17 22:37:11 | 显示全部楼层

回帖奖励 +1 鱼币

ThanksForYUB
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-12-2 08:47:24 | 显示全部楼层
学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-12-5 14:42:20 | 显示全部楼层

回帖奖励 +1 鱼币

学习学习
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-25 15:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表