0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

安卓如何逆向_Dalvik 寄存器,字节码,指令格式 1

jf_78858299 来源:dust安全随记 作者:dust 2023-01-30 16:24 次阅读

0x01 dalvik寄存器

32位,所有类型,  <=32一个寄存器 
 64位:使用两个相邻寄存器

0x02 寄存器的命名法:

v:局部变量寄存器 v0-vn  参数寄存器 vn-vn+m
p:参数寄存器p0 -pn      变量寄存器 v0-vn

0x03 dex文件反汇编工具

.java编译成.class在编译成.dex 最后反编译得到samli文件

.java -->.class -->.dex -->samli

dx.jar ----- .class打包.dex

dx --dex --output=Decrypt.dex com/xxx/xxx/Decrypt.class

Baksamli.jar------- .dex反编译成 samli

java -jar baksmali.jar -o smali_out/class.dex

Samli.jar-----.smali打包成.dex

java -jar smali.jar smali_out/ -o classes.dex

0x04 dalvik字节码类型

Dalvik java
B byte
C char
S short
I int
J long
f float
D double
Z boolean
V void
L java类类型
[ 数组类型

0x05 字段

表示的是成员变量

字段格式: 类型(包名/类名) ->字段名称:字段类型
Lpackage/name/ObjectName;->FieldName:Ljava/lang/String;


相当于


Package com.yjh


Class ObjectName{
  String FieldName;
}

0x05 方法

字段格式: 类型(包名/类名) ->方法名方法的签名信息
Lpackage/name/ObjectName;->MethodName(III)Z


(III)Z:这部分表示方法的签名信息


相当于
Package com.yjh


Class ObjectName{
  public boolean MethodName(int a,int b ,int c){
  }
}

0x06 dalvik指令格式

基础字节码-名称后缀/字节后缀 目的寄存器 源寄存器

名称后缀是wide,表示数据宽度为64位

字节码后缀是from16,表示源寄存器为16位

move-wide/from16 vAA,vBBBB


move   为基础字节码,即opcode
wide   为名称后缀,标识指令操作的数据宽度为64from16 为字节后缀,标识源为一个16位的寄存器引用变量
VAA    为目的寄存器,它始终在源寄存器签名,取值范围为v0-v255
VBBBB  为源寄存器,取值范围v0-65535

Dalvik指令集中大多数指令用到了寄存器作为目的操作数活源操作数,其中

A/B/C/D/E/F/G/H     代表一个四位的数值,
AA/BB/.../HH        代表一个8位的数值,
AAAA/BBBB/.../HHHH  代表一个16位的数值

0x06 dalvik指令

  1. 空操作指令
nop
空操作指令的助记符为nop。它的值为00,通常nop指令被用来做对齐码使用,无实际操作
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5334

    浏览量

    120219
  • 编译
    +关注

    关注

    0

    文章

    657

    浏览量

    32850
  • 安卓
    +关注

    关注

    5

    文章

    2126

    浏览量

    57143
收藏 人收藏

    评论

    相关推荐

    [资料分享]+《Android软件安全与逆向分析》

    不同的寄存器表示方法——v命名法与p命名法 42  3.2.5  Dalvik字节的类型、方法与字段表示方法 43  3.3  Dalvik
    发表于 09-26 10:53

    寄存器与汇编指令

    逆向学习笔记3——寄存器与汇编指令
    发表于 05-07 16:40

    间接寻址及地址寄存器指令

    间接寻址及地址寄存器指令
    发表于 08-12 11:59 19次下载

    寄存器寻址方式

    寄存器寻址方式   寄存器寻址是对由指令选定的工作寄存器(R0--R7)进行读/写,由指令操作码
    发表于 03-14 15:29 2796次阅读

    寄存器Load/Store内存访问指令

    5.4 多寄存器Load/Store内存访问指令寄存器Load/Store内存访问指令也叫批量加载/存储指令,它可以实现在一组
    发表于 10-18 15:56 1次下载

    寄存器的Load/Store指令详解

    (Single Register) 这些指令在ARM寄存器和存储之间提供更灵活的单数据项传送方式。数据项可以是字节、16位半字或32位字。 ② 多
    发表于 10-18 15:57 1次下载
    单<b class='flag-5'>寄存器</b>的Load/Store<b class='flag-5'>指令</b>详解

    Thumb指令集之多寄存器数据传送指令解析

    于过程调用与返回以及存储块拷贝。但为了编码的紧凑性,这两种用法由分开的指令实现,并且这些指令也只使用单一的寻址方式。在其他方面,这些指令的性质与等价的ARM
    发表于 10-19 09:56 0次下载
    Thumb<b class='flag-5'>指令</b>集之多<b class='flag-5'>寄存器</b>数据传送<b class='flag-5'>指令</b>解析

    浅谈单寄存器数据传送指令

    11.5 单寄存器数据传送指令 Thumb指令集支持寄存器的装载和存储,即LDR和STR指令。8和类型的Load/Store
    发表于 10-19 10:04 1次下载

    指令指针寄存器是什么_作用有哪些

    指令指针寄存器IP(X86型CPU)相当于ARM型CPU中的程序计数PC,用于控制程序中指令的执行顺序。正常运行时,IP中含有BIU要取的下一条
    发表于 11-13 09:58 1.2w次阅读
    <b class='flag-5'>指令</b>指针<b class='flag-5'>寄存器</b>是什么_作用有哪些

    指令指针寄存器和指针寄存器差异性在哪儿

    )。它们的关系就是,CPU从指令指针寄存器ip 获得指令的内存地址,然后取出指令,放置到指令寄存器
    发表于 11-13 10:24 8135次阅读
    <b class='flag-5'>指令</b>指针<b class='flag-5'>寄存器</b>和指针<b class='flag-5'>寄存器</b>差异性在哪儿

    逆向基础之寄存器和内存详解

    本文主要介绍的是逆向基础的寄存器和内存方面的信息,首先介绍的是逆向主要是做什么的,其次对编程和机器架构做了个简介,最后详细的阐述了逆向基础的寄存器
    发表于 04-26 09:52 2974次阅读

    技术 | FANUC数据寄存器和位置寄存器的运用介绍

    寄存器指令 Registers① 寄存器指令R[i] i=1~200② 位置寄存器
    的头像 发表于 06-24 17:15 1.7w次阅读
    技术 | FANUC数据<b class='flag-5'>寄存器</b>和位置<b class='flag-5'>寄存器</b>的运用介绍

    寄存器功能

    寄存器功能免费下载。
    发表于 06-21 15:43 1次下载

    如何逆向_Dalvik 寄存器字节指令格式 2

    1. 数据操作指令 1. ``` move Move vA,vB  将vB寄存器的值赋给vA
    的头像 发表于 01-30 16:25 557次阅读

    JTAG 指令寄存器指令译码介绍

    指令寄存器的目的是通过 TDI 信号移入指令。另外,指令寄存器还可以在新指令完全移入之前,存储当
    发表于 02-03 10:42 3301次阅读