吾爱汇编

 找回密码
 立即注册

QQ登录

绑定QQ避免忘记帐号

查看: 8732|回复: 44

[经验资料] 初学者需懂简单的汇编基础-

  [复制链接]
yAxI丶9y 发表于 2014-11-18 10:32 | 显示全部楼层 |阅读模式

本帖最后由 雅熙; 于 2014-11-18 18:44 编辑

内容大致: Unnamed QQ Screenshot20141118102512.jpg Unnamed QQ Screenshot20141118102533.jpg Unnamed QQ Screenshot20141118102545.jpg Unnamed QQ Screenshot20141118102551.jpg Unnamed QQ Screenshot20141118102606.jpg Unnamed QQ Screenshot20141118102624.jpg Unnamed QQ Screenshot20141118102631.jpg Unnamed QQ Screenshot20141118102636.jpg


载地址(为什么不能上传.7z的文件!!!):初学者需懂简单的汇编基础1-2.7z
115网盘礼包码:5lbclpitljnj
http://115.com/lb/5lbclpitljnj

百度网盘:链接: http://pan.baidu.com/s/1mghzlFU 密码: wxxl





跳转命令
-------------------------------------------------------------根据条件作出是否跳转的决定,通常前面会有一个判断语句,例如:
    CMP AX,BX
    JZ XX //jump zero
上面两条命令意为用 AX 减 BX,它的值如果为 0 则跳转到 XX 的标号行。
常用的跳转命令有:
    JZ/JE   相等或为零为则跳转
    JNZ/JNE  不相等或不为零则跳转
    JL/JLE  小于/小于或等于则跳转
    JG/JGE  大于/大于或等于则跳转
    JMP    无条件跳转
-------------------------------------------------------------
比较语句
-------------------------------------------------------------
    CMP AX,BX  //AX 寄存器减去 BX 寄存器的内容
    AND AX,BX  //AX 与 BX 做“与运算”
    OR AX,BX   //AX 与 BX 做“或运算”
    TEST AX,BX 与 AND AX,BX 命令有相同效果
    XOR AX,AX 使 AX 的内容清零,每个寄存器与自己作异或运算等于清零动作
-------------------------------------------------------------
子程序
-------------------------------------------------------------
一个子程的模样长得像这个样子
    CALL 15F:334422
子程式是个很重要的概念,它是主程式的一个分支,用来做特定动作。
打个比方:你要上班,先你是走路到车站,然后上车,然后下车,然后走到自己的办公室。
这里如果要把上班编为一段程式的话,那么就可以把“走路”、“搭车”、“走到办公室”做为分支程式来处理。
说得再通俗一点就是:你要逆向的程式不可能就是一条主程式到底,肯定会呼叫下面的子程式,由子程式来处理你发送的注册信息,然后比较,然后标记是否注册正确,这些都是靠它来完成的。
所以说,逆向的关键在于,你找准程式在哪儿将会作注册判断,并进入那个注册子程式,仔细观察,你就成功了。(子程式的返回码是 RET)
-------------------------------------------------------------
算术运算
-------------------------------------------------------------
    ADD AX,BX  加法运算   AX=AX+BX
    SUB AX,BX  减法运算   AX=AX-BX
    INC AX   寄存器加一  AX=AX+1
    DEC AX   寄存器减一  AX=AX-1
    MUL     乘法运算
    DIV/idiv     除法运算
-------------------------------------------------------------
数据操作
-------------------------------------------------------------
    MOV AX,BX 数据传送指令,将 BX 的值移送到 AX 中
    XCHG AX,BX 将 AX 与 BX 的值互换
8086/8088指令集
为了便于查询,这里分类列出8086/8088汇编指令:

数据传送指令
MOV
功能: 把源操作数送给目的操作数
语法: MOV 目的操作数,源操作数
格式: MOV r1,r2 或 MOV r,m 或 MOV m,r 或 MOV r,data

XCHG
功能: 交换两个操作数的数据
语法: XCHG
格式: XCHG r1,r2 或 XCHG m,r 或 XCHG r,m

PUSH,POP
功能: 把操作数压入或取出堆栈
语法: PUSH 操作数 POP 操作数
格式: PUSH r 或 PUSH M 或 PUSH data POP r 或 POP m

PUSHF,POPF,PUSHA,POPA // PUSHFD POPFD PUSHAD POPAD
功能: 堆栈指令群
格式: PUSHF POPF PUSHA POPA

LEA,LDS,LES
功能: 取地址至寄存器
语法: LEA r,m LDS r,m LES r,m

XLAT(XLATB)
功能: 查表指令
语法: XLAT XLAT m
算术运算指令

ADD,ADC
功能: 加法指令
语法: ADD OP1,OP2 ADC OP1,OP2
格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data
影响标志: C,P,A,Z,S,O

SUB,SBB
功能:减法指令
语法: SUB OP1,OP2 SBB OP1,OP2
格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data
影响标志: C,P,A,Z,S,O

INC,DEC
功能: 把OP的值加一或减一
语法: INC OP DEC OP
格式: INC r/m DEC r/m
影响标志: P,A,Z,S,O

NEG
功能: 将OP的符号反相(取二进制补码)
语法: NEG OP
格式: NEG r/m
影响标志: C,P,A,Z,S,O

MUL,IMUL
功能: 乘法指令
语法: MUL OP IMUL OP
格式: MUL r/m IMUL r/m
影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)

DIV,IDIV
功能:除法指令
语法: DIV OP IDIV OP
格式: DIV r/m IDIV r/m

CBW,CWD  //change byte word // change word dword
功能: 有符号数扩展指令
格式: CBW CWD

AAA,AAS,AAM,AAD
功能: 非压BCD码运算调整指令
格式: AAA AAS AAM AAD
影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)

DAA,DAS
功能: 压缩BCD码调整指令
格式: DAA DAS
影响标志: C,P,A,Z,S
字符串操作指令

MOVSB,MOVSW,MOVSD
功能: 字符串传送指令
格式: MOVSB MOVSW MOVSD
标志位: 无

CMPSB,CMPSW,CMPSD
功能: 字符串比较指令
格式: CMPSB CMPSW CMPSD
标志位: C,P,Z,S,O

SCASB,SCASW  //scansb
功能: 字符串搜索指令
格式: SCASB SCASW
标志位: C,P,Z,S,O

LODSB,LODSW,STOSB,STOSW
功能: 字符串载入或存贮指令
格式: LODSB LODSW STOSB STOSW
标志位: 无

REP,REPE,REPNE
功能: 重复前缀指令集
格式: REP 指令S REPE 指令S REPNE 指令S
标志位: 依指令S而定

位运算指令集
AND,OR,XOR,NOT,TEST
功能: 执行BIT与BIT之间的逻辑运算
格式: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m
影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位

SHR,SHL,SAR,SAL
功能: 移位指令
格式: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL
影响标志: C,P,Z,S,O

ROR,ROL,RCR,RCL
功能: 循环移位指令
格式: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL
影响标志: C,P,Z,S,O
程序流程控制指令

CLC,STC,CMC
功能: 设定进位标志
格式: CLC STC CMC
标志位: C

CLD,STD
功能: 设定方向标志
格式: CLD STD
标志位: D

CLI,STI
功能: 设定中断标志
格式: CLI STI
标志位: I

CMP
功能: 比较OP1与OP2的值
格式: CMP r/m,r/m/data
标志位: C,P,A,Z,O

JMP
功能: 跳往指定地址执行
格式: JMP 地址

JXX
功能: 当特定条件成立则跳往指定地址执行
格式: JXX 地址
XX为下列值:
   A: ABOVE,当C=0,Z=0时成立
   B: BELOW,当C=1时成立
   C: CARRY,当CF=1时成立
   CXZ: CX寄存器的值为0(ZERO)时成立
   E: EQUAL,当Z=1时成立
   G: GREATER(大于),当Z=0且S=0时成立
   L: LESS(小于),当S不为零时成立
   N: NOT(相反条件),需和其它符号配合使用
   O: OVERFLOW,O=1时成立
   P: PARITY,P=1时成立
   PE: PARITY EVEN,P=1时成立
   PO: PARITY ODD,P=0时成立
   S: SIGN,S=1时成立
   Z: ZERO,Z=1时成立

LOOP
功能: 循环指令集
语法: LOOP 地址

LOOPE(Z)
格式:LOOPNE(Z) 地址
标志位: 无

CALL,RET
功能: 子程序调用,返回指令
语法: CALL 地址 RET RET n
标志位: 无

INT,IRET
功能: 中断调用及返回指令
语法: INT n IRET
标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器

处理器状态控制指令
NOP
功能: 空操作指令。不执行任何操作,但要花费CPU一个机器周期
格式: NOP

HLT
功能: 暂停指令。CPU不执行任何操作,一直处于暂停状态,但IP指向HLT的下一条指令。
格式: HLT
脱离HLT状态的方式:1、CPU复位;2、CPU响应中断

ESC,WAIT,LOCK
功能: 用于多处理器系统。其中ESC是交权指令;WAIT是等待指令;LOCK是总线封锁指令



评分

参与人数 34HB +51 THX +27 收起 理由
29590 + 1
24567 + 1
琉璃天空 + 1
sjtkxy + 1 + 1
一路走来不容易 + 1
Soul1999 + 1
zxjzzh + 1 [吾爱汇编论坛52HB.COM]-感谢楼主热心分享,小小评分不成敬意!
消逝的过去 + 1
冷亦飞 + 1
无影无踪 + 1 [吾爱汇编论坛52HB.COM]-学破解防破解,知进攻懂防守!
jaunic + 1
hnymsh + 1
lies + 1
gwqxpj + 1 + 1 [快捷评语]--评分=感恩!简单却充满爱!感谢您的作品!
hardchao + 1 + 1 [快捷评语] - 评分=感恩!简单却充满爱!感谢您的作品!
a1186494930 + 2 + 1 [快捷评语] - 分享精神,是最值得尊敬的!
freedom + 1 + 1 [快捷评语] - 分享精神,是最值得尊敬的!
Forever丶小桀 + 2 + 1 【违规行为】请查阅http://www.xuepojie.com/thread-116-1-1.html
梁非凡 + 1 要学破解 好像也要会汇编
风刃 + 3 + 1 支持原创,感谢楼主!
Shark恒 + 5 + 1 论坛有你更精彩!感谢楼主!
轻描 + 3 + 1 感谢!新技能get√
antony + 3 + 1 汇编一点都不懂,慢慢学起吧,看看这个教程能不能看懂
lyf1995 + 3 + 1 论坛有你更精彩!感谢楼主!
夜月幽伤 + 1 + 1 Get!Thanks!
yexpin + 5 + 1 我很赞同!
视点 + 1 我很赞同!
decent001 + 3 + 1 不错,找了很久!
yusenny + 1 + 1 积极评分从我做起,感谢!
zx2cwf + 3 + 1 我很赞同!
wangsm + 3 + 1 Get!Thanks!
jasson29 + 1 + 1 正想学习当初遗忘的汇编,感谢楼主!
彡倾心 + 2 转的一手好帖!学习了!
逍遥枷锁 + 1 + 1 支持原创,感谢楼主!

查看全部评分

吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
 楼主| yAxI丶9y 发表于 2014-11-18 12:42 | 显示全部楼层

雪花飘飘 发表于 2014-11-18 11:25
没有115网盘,可有百度的吗?

百度的号容量放不下了。
我重新注册个号
链接: http://pan.baidu.com/s/1mghzlFU 密码: wxxl
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
逍遥枷锁 发表于 2014-11-18 10:39 | 显示全部楼层

占沙发了,老师这是你自编的吗,真是给力啊,向老师学习致敬。
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
Crack_TTds 发表于 2014-11-18 10:49 | 显示全部楼层
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
芃元 发表于 2014-11-18 11:13 | 显示全部楼层

......
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
wangsm 发表于 2014-11-18 11:22 | 显示全部楼层
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
雪花飘飘 发表于 2014-11-18 11:25 | 显示全部楼层

没有115网盘,可有百度的吗?
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
帮助别人 发表于 2014-11-18 11:54 | 显示全部楼层

真是给力啊,向老师学习致敬。
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
 楼主| yAxI丶9y 发表于 2014-11-18 12:37 | 显示全部楼层


珍惜帐号 ,请勿灌水。
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
 楼主| yAxI丶9y 发表于 2014-11-18 12:44 | 显示全部楼层

逍遥枷锁 发表于 2014-11-18 10:39
占沙发了,老师这是你自编的吗,真是给力啊,向老师学习致敬。

只是把散乱的教程稍微总结了下。
吾爱汇编论坛-学破解,防破解!知进攻,懂防守!逆向分析,软件安全!52HB.COM
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

警告:本站严惩灌水回复,尊重自己从尊重他人开始!

1层
赞帖
2层
3层
4层
5层
6层
7层
8层
10层

免责声明

吾爱汇编(www.52hb.com)所讨论的技术及相关工具仅限用于研究学习,皆在提高软件产品的安全性,严禁用于不良动机。任何个人、团体、组织不得将其用于非法目的,否则,一切后果自行承担。吾爱汇编不承担任何因为技术滥用所产生的连带责任。吾爱汇编内容源于网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除。如有侵权请邮件或微信与我们联系处理。

站长邮箱:SharkHeng@sina.com
站长QQ:1140549900


QQ|RSS|手机版|小黑屋|帮助|吾爱汇编 ( 京公网安备11011502005403号 , 京ICP备20003498号-6 )|网站地图

Powered by Discuz!

吾爱汇编 www.52hb.com

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