汇编与逆向(一)-汇编工具简介

RadASM是一款著名的WIN32汇编编辑器,支持MASM、TASM等多种汇编编译器,Windows界面,支持语法高亮,自带一个资源编辑器和一个调试器。

一、汇编IDE工具:RadASM

RadASM有内置的语言包

下载地址:RadASM assembler IDERadASM assembler IDE

1、把这三个下载之后,解压主程序

比如到: I:\RadASM 再解压汇编包语言包 。注意:语言包的Language目录、汇编包中的文件及目录 要放在主程序所在目录中,比如: I:\RadASM。

说明见readme.txt

2、设置中文语言

弄好后点击 RadASM.exe 启动RadASM,然后点击 Option:

3、配置RadASM

重启RadASM,点击 选项==>编程语言

4、使用方法

可以参考: radasm的汇编语言操作入门 - nyc1893 - 博客园 (cnblogs.com)

5、中文乱码问题的解决

如果你不需要再汇编程序里使用中文,那你就已经完事了,但是RadASM本身如果程序里有中文就会乱码, 下面是解决办法:调节字体。

点击 选项==>字体选项

点击 代码编辑 ,选择字体(这里推荐微软雅黑 ),再选择编码, 别忘了确定应用!

点击确定应用 ,**确定,**OK!

二、汇编编译工具:MASM32

官网下载地址:MASM32 SDKhttps://masm32.com/download/masm32v11r.zip

1、安装

解压缩masm32v11r.zip,点击install.exe,选择分区,一直"确定"

直到:

点击ok

最后

我的Masm安装在I分区中,如图:

2、设置系统环境变量

注:如果不使用命令行编译,可忽略,直接在RadAsm中设置Masm32路径,见下文。

设置三个Window系统环境变量:include、lib,path增加masm32

include =c:\masm32\include

lib=c:\masm32\lib

path=c:\masm32\bin

完成后,命令行输入ml,回车,出现以下页面,表示配置成功

3、命令行编译asm

Masm32目录中新建source文件夹(可以是其他任意目录),记事板写入以下代码,到存到c:\masm32\source\helloword.asm

复制代码
.386
.model flat ,stdcall ;32bit memory model
option casemap :none ;case sensitve
 
include windows.inc
include user32.inc
include kernel32.inc
 
includelib user32.lib
includelib kernel32.lib
 
.const 
	g_szHello db 'Hello World',0
	g_szTitle db 'PE',0
.code
	
start:
	invoke MessageBox,NULL,Offset g_szHello,Offset g_szTitle,MB_OK
	invoke ExitProcess,0
	
end start

命令行编译:ml -c -coff C:\masm32\source\HelloWord.asm

编译成功,出现obj文件

命令行链接:link -subsystem:windows HelloWord.obj

出现exe文件

双击exe文件,出现以下窗口,运行成功!

三、RadAsm设置Masm32路径

F5,Assemble汇编成功

四、使用RadAsm汇编hello word!

1、创建一个无资源的汇编工程

2、输入代码

复制代码
.386
.model flat ,stdcall ;32bit memory model
option casemap :none ;case sensitve
 
include windows.inc
include user32.inc
include kernel32.inc
 
includelib user32.lib
includelib kernel32.lib
 
.const 
	g_szHello db 'Hello World',0
	g_szTitle db 'PE',0
.code
	
start:
	invoke MessageBox,NULL,Offset g_szHello,Offset g_szTitle,MB_OK
	invoke ExitProcess,0
	
end start

3、Ctrl+F5,完成编译运行

注意:默认Masm32没有Doslink.exe,编译纯Dos的App时,,

Alt+Ctrl+F5会报错,Link生成obj失败!按Ctrl+F5 构建并运行,成功生成exe文件后再进入调制器中运行。

4、在调试器中运行

按alt+7 打开Register列表,按F10 即可让程序在单步状态下运行,同时相应的查看包括PSW寄存器和其他寄存器的状态情况。

标志位对应的符号如下:

radasm软件界面简单,不光对于新手容易上手,还拥有较强的工程管理功能,加之众多插件的支持,使得它用汇编语言编写Windows软件变得得心应手。

相关推荐
天途小编17 小时前
融合空域相关法规核心条款汇编
汇编·无人机
天途小编17 小时前
无人机相关国家根本条例核心汇编
汇编·无人机
2301_789015622 天前
C++:模板进阶
c语言·开发语言·汇编·c++
Hollis Arthur4 天前
mips栈帧详解
开发语言·汇编·学习·mips
fengye2071614 天前
板凳----------(枯藤 )vs2019+win10(第四章-3)
汇编
white-persist6 天前
【攻防世界】reverse | re1-100 详细题解 WP
c语言·开发语言·网络·汇编·python·算法·网络安全
sulikey7 天前
如何使用 Visual Studio 代替 OllyDbg 完成汇编语言实验
汇编·ide·debug·visual studio·ollydbg
浩浩测试一下7 天前
C&&汇编中的调用约定
大数据·汇编·安全·web安全·网络安全·系统安全
猫猫的小茶馆8 天前
【ARM】BootLoader(Uboot)介绍
linux·汇编·arm开发·单片机·嵌入式硬件·mcu·架构
white-persist8 天前
【攻防世界】reverse | answer_to_everything 详细题解 WP
c语言·开发语言·汇编·python·算法·网络安全·everything