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

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软件变得得心应手。

相关推荐
DebugKitty3 小时前
硬件开发2-汇编2(ARMv7-A)
汇编·bx·stmdb
Aczone284 小时前
硬件(六)arm指令
开发语言·汇编·arm开发·嵌入式硬件·算法
Skylar_.16 小时前
嵌入式 - ARM(2)汇编
汇编·arm开发
10岁的博客3 天前
深入解析汇编语言的奥秘
汇编
阿发君13 天前
ARMCC和gcc汇编文件互相转换的高效方法
汇编
JCBP_15 天前
QT(1)
开发语言·汇编·c++·qt
浩浩测试一下16 天前
06高级语言逻辑结构到汇编语言之逻辑结构转换 for (...; ...; ...)
汇编·数据结构·算法·安全·web安全·网络安全·安全架构
weixin_4707403617 天前
某算法的python执行汇编
汇编·python·算法
small_wh1te_coder25 天前
GCC深度剖析:从编译原理到嵌入式底层实战
汇编·c++·面试·嵌入式·状态模式·c
白书宇1 个月前
5.从零开始写LINUX内核--从实模式到保护模式的过渡实现
linux·汇编·数据库·开源