分享
 
 
 

【原创】在MASM32中使用自己的STUB

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

这是我测试PE格式的STUB的源代码,可显示当前所用操作操作系统版本。

dos下的stub部分源代码---调用DOS中断服务程序

@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@

; FileName: os_type.asm

; function: Reports current operation system type

; Author : Purple Endurer

; Version : 0.1

;

; OS Name Offset of INT 08h Offset of INT 43h

; -------------------------------------------------------

; MS DOS 7.00 001Fh 5710h

; MS DOS 7.10 18DEh 6EE5h

; UCDOS 1AF3h

; UCDOS98 1AEBh 6E20h

; MSDOS mode 0000h

; PDOS95 0A50h 6E20h

;

; Date Summary

; -------------------------------------------------------

; 2002.04.07 Created from software paper 95P125

; 2002.06.11 Show version if os is MS-DOS

; 2002.08.07 Convert it to DOS EXE format to be stub

; program in PE format execute file

; 2004.02.09 Added the condition asm var 'UseStack'

; Question:

; Why can this program run normally with stack segment,

; though there is push and pop instruction in bin2dec proc?

UseStack equ 0

data segment

strMSDOS db "MS DOS "

cMajorVer db ' '

db '.'

cMinorVer db " $"

strUCDOS db "UCDOS"

cUCDOSVer db " 98特别版$"

strPDOS95 db "Windows95中文DOS方式PDOS95$"

data ends

if UseStack

sseg segment stack

db 10 dup(?)

sseg ends

endif

code segment

;--------------------------------------

if UseStack

assume cs: code, ds: data, ss: sseg

else

assume cs: code, ds: data

endif

main proc

start:

mov ax, data

mov ds, ax

if UseStack

mov ax, sseg

mov ss, ax

endif

mov ah, 30h ; Get Version

int 21h

add al, '0'

mov cMajorVer, al

mov bx, offset cMinorVer

call bin2dec

mov ax, 3508h

int 21h

mov dx, offset strMSDOS

mov ah, 09h

int 21h

cmp bx, 1fh

je @end ;Here is DOS 7.00 only

cmp bx, 18deh

je @End ;Here is DOS 7.10 only

mov dx, offset strUCDOS

cmp bx, 1aebh

je @Report

cmp bx, 1af3h

jne @next2

mov cUCDOSVer, '$'

jmp @report

@next2:

mov dx, offset strPDOS95

cmp bx, 0a50h

jne @End

@Report:

;mov ah, 09h

int 21h

@End:

mov ax, 4c00h

int 21h

main endp

; ========================================================

; Input : AH = the Binary will be translated)

; BX = First offset of memory us to store the result

; Output: BX = First offset of memory stored the result

; --------------------------------------------------------

bin2dec proc

push dx

mov dl, 10

@LoopDiv:

mov al, ah

xor ah, ah

div dl ; (AL) <- (AX) / (DL) (AH) <- (AX) % (DL)

add al, '0'

mov [bx], al

inc bx

cmp ah, 10

jg @LoopDiv

add ah, '0'

mov [bx], ah

pop dx

ret

bin2dec endp

;=========================================

code ends

end main

WINDOWS下的源代码--调用 API 函数GetVersionEx()

;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

;FileName: StubDemo.asm

; Fuction: Demo how to use the custome stub of PE exe files.

; Author: Purple Endurer

; Date Summary

; -------------------------------------------------------

; 2002.04.07 Created!

;<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

.386

.model flat, stdcall

option casemap:none

include \masm32\include\windows.inc

include \masm32\include\kernel32.inc

include \masm32\include\user32.inc

includelib \masm32\lib\user32.lib

includelib \masm32\lib\kernel32.lib

bDetailInfo equ 0

.data

szMsgBoxTitle db "当前操作系统",0

if bDetailInfo ;?????? bDetailInfo

szWin31 db "Win32s on Windows 3.1 ", 0

szWin9x db "Win32 on Windows 95 ", 0

else

szWin31 db "Windows 3.1 ", 0

szWin9x db "Windows 95 ", 0

endif ;?????? bDetailInfo

szWinNT db "Windows NT ", 0

szFormat4OsVer db "%lu.%lu.%lu", 0

szGetOsInfoFail db "取操作系统信息失败!", 0

.data?

OsVer OSVERSIONINFO <>

szOsVerInfo db 255 dup (?)

szOsVerInfoTmp db 255 dup (?)

.code

start:

mov OsVer.dwOSVersionInfoSize, SIZEOF OSVERSIONINFO

invoke GetVersionEx, ADDR OsVer

.if eax

mov eax, OsVer.dwPlatformId

;Identifies the build number of the operating

;system in the low-order word For Win9X

.if eax == VER_PLATFORM_WIN32s

mov esi, OFFSET szWin31

and OsVer.dwBuildNumber, 0FFFFh

.elseif eax == VER_PLATFORM_WIN32_WINDOWS

mov esi, OFFSET szWin9x

and OsVer.dwBuildNumber, 0FFFFh

.else ; eax ==VER_PLATFORM_WIN32_NT

mov esi, OFFSET szWinNT

.endif

invoke lstrcpy, ADDR szOsVerInfo, esi

invoke wsprintf, ADDR szOsVerInfoTmp,ADDR szFormat4OsVer, OsVer.dwMajorVersion,OsVer.dwMinorVersion, OsVer.dwBuildNumber

invoke lstrcat, ADDR szOsVerInfo, ADDR szOsVerInfoTmp

invoke lstrcat, ADDR szOsVerInfo, ADDR OsVer.szCSDVersion

mov edi, OFFSET szOsVerInfo

mov esi, MB_OK OR MB_ICONINFORMATION

.else

mov edi, OFFSET szGetOsInfoFail

mov esi, MB_OK OR MB_ICONWARNING

.endif

invoke MessageBox, NULL, edi, addr szMsgBoxTitle, esi

invoke ExitProcess,NULL

end start

到命令行,把我们自己定义的stub连接进来

命令是:

\masm32\bin\link /stub:<filename.exe> /subsystem:windows <objectname.obj>

本例中使用的命令是:

\masm32v6\WORKS\my_stub>\masm32\bin\link /stub:stub.exe /subsystem:windows stubdemo.obj

尽管会看到下面的警告信息,但程序仍然是可以正常运行的。

Microsoft (R) Incremental Linker Version 5.12.8078

Copyright (C) Microsoft Corp 1992-1998. All rights reserved.

stub.exe : warning LNK4060: stub file missing full MS-DOS header; rebuild stub with /KNOWEAS 16-bit LINK option

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有