首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

扩大Android攻击面:React Native Android应用程序分析

在这篇文章中,我们介绍如何根据APK文件来获取到React Native JavaScript,并根据这些信息分析出API以及其他敏感信息。...一般来说,在对Android应用程序进行逆向分析,我们需要使用dex2jar来对APK文件进行反编译,然后使用JD-GUI来进行下一步分析。...请注意:dex2jar的工作原理是Java字节换为Dalvik字节。因此,我们无法保证所有的输出都是有效的,此时就需要使用Smali工具来分析Dalvik字节了。...在这个文件夹中,找到一个名为“index.android.bundle”的文件,这个文件包含所有的React JavaScript代码。...当然了,只有当我们给该脚本提供目标Firebase数据库的API密钥,脚本才会有权限来读取数据库中的内容。如果你还想对目标数据库进行类似写入之类的操作,请参考Pyrebase的【操作手册】。

9.8K30

【错误记录】记录 Android 命令行执行 Java 程序中出现的错误 ( dx 打包 PC 可执行文件报错 | dalvik 命令执行 kotlin 编译的 dex 文件报错 )

系统中执行 Java 程序 , 【开发环境】Android 命令行中执行 Java 程序 ( IntelliJ IDEA 中创建 Java / Kotlin 工程 | dx 打包 DEX 字节文件...IDEA 中创建 Java / Kotlin 工程 | dx 打包 DEX 字节文件 | dalvikvm 命令 ) 三、编译在 PC 上可执行的 Java / Kotlin JAR 包 生成的 JAR...包打包成 dex 文件 , 打包过程中出错 ; 报错信息 : D:\002_Project\003_Java_Work\workspace\AndroidShell\out\artifacts>dx...--dex --output kotlin.dex AndroidShell_jar\AndroidShell.jar PARSE ERROR: class name (kotlin/reflect/...; aborting D:\002_Project\003_Java_Work\workspace\AndroidShell\out\artifacts> 直接打包字节文件是成功的 , 打包 PC

78110
您找到你想要的搜索结果了吗?
是的
没有找到

ART 在 Android 安全攻防中的应用

) Java 字节换为 Dalvik 字节,并将所有生成的类打包到统一的 DEX 文件中,最终和资源文件一起 zip 压缩为 .apk 文件。...dexopt dex 文件优化为 odex 文件,即 optimized-dex 的缩写,其中包含的是优化后的 Dalvik 字节,称为 quickend dexdex2oat 基于 LLVM,...,比如: 当所执行的方法是 Native 方法,这时只有二进制代码,不存在字节,自然无法解释执行; 当所执行的方法无法调用,比如 access_flag 判定无法访问或者当前方法是抽象方法; 当所执行的方式是代理方法...如果当前内存中的 dex 部分偏移被恶意修改,那么还可以通过 method->GetCodeItem() 获取对应方法解密后的字节地址进行手动储恢复。...,字节的执行顺序打乱,插入各种无效指令来阻碍逆向工程;又或者字节的实现抽批量自动取到 JNI 层,并辅以二进制级别的安全加固,这种方案通常称为 Java2C,即将 Java 代码转译成 C 代码编译来防止逆向分析

1.1K10

从JVM到Dalivk再到ART(class,dex,odex,vdex,ELF)

它可以支持已转换为 .dex 格式的 Java 应用程序的运行,.dex 格式是专为Dalvik 设计的一种压缩格式,适合内存和处理器速度有限的系统。...字节文件: 详见:使用dxclassdex总结 ?...在 Dalvik 下,应用每次运行的时候,字节都需要通过即时编译器(just in time ,JIT)转换为机器,这会拖慢应用的运行效率,而在ART 环境中,应用在第一次安装的时候,字节就会预先编译成机器...但是为了每次启动都去掉从字节到机器的编译过程,Google 又从 Dalivk 中优化出了 ART,在其安装应用的时候 dex 文件进行预处理生成可执行的 oat 文件。...应用在安装不做编译,而是解释字节,所以可以快速启动。ART中有一种新的、更快的解释器,通过一种新的 JIT 完成,但是这种 JIT 的信息不是持久化的。

1.9K21

Dalvik虚拟机原理及Xposed hook原理

dex文件中,方法体里面的内容最终存储在classData区域,方法体里面存储的是二进制的字节。...文件,解析字节为对应的smali语法(反汇编),同时也可以smali语法的文件重新转换为字节生成dex文件(汇编)。...dex优化过程,其实是一些字节换为dalvik相关的, 优化后的等价字节。...虚拟机在调用directMethod,在构建好方法栈以后,pc指针指向了insns,于是可以从内存中取得字节,然后解释执行。...爱加密的方法则是,方法体里面的字节dex中抠出来,加密到了自己的so中,在app运行时,从so中解密出方法体,然后修改mmap对应的内存,还原内存结构。

1.6K10

Android 使用android-support-multidex解决Dex超出方法数的限制问题

那么让我们看一下为什么会引起这种错误:         在Android系统中,一个App的所有代码都在一个Dex文件里面。Dex是一个类似Jar的存储了多有Java编译字节的归档文件。...这里需要强调的是,Dex和Jar一样是一个归档文件,里面仍然是Java代码对应的字节文件。...常见问题 DexException: Library dex files are not supported in multi-dex mode,你可能会见到如下的错误: Error:Execution...Error Code:   2   Output:       UNEXPECTED TOP-LEVEL EXCEPTION:       com.android.dex.DexException...javaMaxHeapSize "2g"     }   }       使用eclipse的开发人员可以参考Google官方文档 https://developer.android.com/tools/building

1.4K80

APK体积优化有感

所以要消除这种赋值 确认目标: Filed是当前类的变量,Field在init和clinit中赋值,并且之前没有付过非默认值,且此次赋值是默认值,那么这个赋值就是可以优化的 实现: 1.遍历init,clinit的字节找到...5.遍历完整个字节之后进行统一删除 删除无用代码 一.使用proguard 的 -assumenosideeffects配置消除无副作用的函数调用 当方法不会修改堆上某个对象或者栈上方法参数的值,...减少dexmethod,Fidle数量 当超出65536 ,会新创建一个dex包来存放。...找到getsatic指令,分析其访问的字段是否在1中出现,接着消除这条指令替换为对应的常量入栈即可 风险: 替换为直接传播后如果不在同一个dex文件会有dex体积变大的风险。...观察字节会发现访问R文件的getstatic指令会变成ldc直接引入id常量 module:未使用常量消除 由于R文件中的id不能重复,而原生的aapt是根据类别和顺序生成的资源id,是固定的。

62030

Android ClassLoader详解

只不过Android平台上虚拟机运行的是Dex字节,一种对class文件优化的产物,传统Class文件是一个Java源码文件会生成一个.class文件,而Android是把所有Class文件进行合并,...上面"支持加载APK、DEX和JAR,也可以从SD卡进行加载"指的就是这个路径,最终做的是dexPath路径上的文件ODEX优化到内部位置optimizedDirectory,然后,再进行加载的。...ART能够把应用程序的字节换为机器,是Android所使用的一种新的虚拟机。...它与Dalvik的主要不同在于:Dalvik采用的是JIT技术,字节都需要通过即时编译器(just in time ,JIT)转换为机器,这会拖慢应用的运行效率,而ART采用Ahead-of-time...(AOT)技术,应用在第一次安装的时候,字节就会预先编译成机器,这个过程叫做预编译。

1.3K100

NDK--andfix热修复之art虚拟机

在dalvik虚拟机中,应用启动首先会加载dex成class字节,然后采用JIT技术,字节都需要通过即时编译器(just in time ,JIT)转换为机器(CPU真正识别二进制),虽然转换时会利用缓存技术优化...在art虚拟机中,在应用安装,就通过dex2oat工具把dex文件转换为oat文件,oat文件中同时存放着字节和机器,这就造成了art虚拟机下安装应用比较慢,应用运行速度却大大提升了。...上次我们在api19以下的情况,两个Method对象传给native层进行函数指针替换,今天来做19以上的适配 package com.aruba.andfixapplication; import...uint32_t super_class_; // If class verify fails, we must return same error on subsequent...uint32_t verify_error_; // Virtual method table (vtable), for use by "invoke-virtual".

55140

JAVA虚拟机与Android虚拟机的区别

->打包到dex中->DVM通过解释DEX文件来执行这些字节。...Dalvik虚拟机 SDK中有个dx工具负责JAVA字节换为Dalvik字节,**对JAVA类文件重新排列,**所有JAVA类文件中的常量池分解,消除其中的冗余信息,重新组合形成一个常量池,...AOT:编译器在编译直接程序源码编译成目标机器,运行时直接运行机器。...Dalvik虚拟机执行的是dex字节,ART虚拟机执行的是本地机器 Dalvik执行的是dex字节,依靠JIT编译器解释执行,运行时动态地执行频率很高的dex字节翻译成本地机器,然后在执行,...但这个过程发生在应用程序的运行过程中,应用程序每一次重新运行的时候,都要重新做这个翻译工作 ART:安装应用的时候,dex中的字节将被编译成本地机器,之后每次打开应用,执行的都是本地机器

1.1K20

001

数组类型 Lpackage/name/ObjectName;->FieldName:Ljava/lang/String; 字段格式:类型(包名+类名)-> 字段名称:字段类型 dalvik 指令 基础字节...- 名称后缀/字节后缀 目的寄存器 源寄存器 nop 空操作指令,值为 00,对其代码,无实际操作 move 数据操作指令 move 作用: 1、赋值 2、接受方法返回值操作 3...这条指令占用两个字节,值为 0xooff (Android4.0新增) 实例操作指令 check-cast vAA, type@BBBB vAA 寄存器中的对象引用转换为指定类型 instance-of...vCCCC ..vNNNN}, type@BBBB 指令功能与 filled-new-array {vC, vD, vE, vF, vG}, type@BBBB 相同,只是参数寄存器使用 range 字节指定了取值范围...1换为数据类型2 数据运算指令 add/sub/mul/div/rem 加、减、乘、除、模 and/or/xor 与、或、异或 shl/shr/ushr 有符号左移、有符号右移、无符号右移

64620

android apk 防止反编译技术第二篇-运行时修改字节

接下来我们介绍另一种防止apk反编译的技术-运行时修改字节。这种方法是在工作中在实现app wrapping,看到国外的一篇关于android 安全的介绍实现的并且独创。...根据上面的dex文件的格式结构,dalvik虚拟机运行dex文件执行的字节就存在method_ids区域里面。...二、odex文件格式 apk安装或启动,会通过dexopt来dex生成优化的odex文件。...三、方法实现 要实现修改字节,就需要先定位到想要修改得代码的位置,这就需要先解析dex文件。...根据上面的讲述相信大家对运行时修改字节的技术有了一定的了解,下一篇我们讲解另一种android apk防止反编译技术,期待大家的捧场。

1.4K110

Android 构建过程分析

Tool)处理后,会输出2个文件:一个R.java,为项目各资源分配了不同的id,和java源码一起参与到后续的编译过程,id为4字节无符号整数,最高字节表示package id,次高字节表示type...下一步要进行的是通过javac命令java源码编译成.class字节,用以编译的classpath包含以下内容: android.jar,具体版本由targetSdkVersion指定; build.gradle...中添加的第三方依赖; 编译后可对代码进行混淆处理,主要包括删除无用类、字节优化、重命名等操作,只需在build.gradle中配置混淆规则即可 buildTypes { release {...经过上一阶段编译的处理,已经生成了标准的java字节,可在标准的java虚拟机上运行。但android使用了它特有的dalvik虚拟机,这就需要我们为它提供另一不同的格式。...当项目发展到一定规模,需要进行分dex处理,可通过上述步骤生成的maindexlist.txt指定dex该如何拆分。 遗憾的是,以上关于分dex的内容都是理想的情况,现实却很残酷。

3.1K40

Android编译优化:D8和R8

代码编译成字节,进而运行在虚拟机当中,这样就无需关注底层操作系统、内存和CPU的差异,应用开发者只需要关注业务逻辑。...回到Android,我们的代码是需要跑在容量更小,电量更小的移动设备当中,JVM那套就不太适用了,所以Google就针对Android开发了Dex编译器来编译dex格式的字节,而运行Dex字节的Android...脱糖 即在编译阶段将在语法层面一些底层字节不支持的特性转换为基础的字节结构,(比如 List 上的泛型脱糖后在字节层面实际为 Object);Android 工具链对 Java8 语法特性脱糖的过程可谓丰富多彩...D8 D8的功能是Java字节转化成dex代码,D8作为DX的一个替代方案。编译流程如下图所示: ? Android Studio 3.1版本开始,D8作为默认的Dex编译器。...编译占用内容更小 .dex文件更小 D8编译的.dex文件拥有相同或者更好的运行性能 如果你的工程已经使用Java 8尽可能开启D8编译,不然可能会出现编译错误。

2.2K40

说说编译插桩

Java-字节-dex 如图,这是Java代码的编译流程。从图中可以看出,编译插桩可以从两个方面着手 Java 文件。...字节(Bytecode)。这是一般情况下讨论最多的操作字节的方式。可以操作“.class”的 Java 字节,也可以操作“.dex”的 Dalvik 字节,这取决于我们使用的插桩方法。...Java字节,里面演示了如何字节反过来解析出对应的class文件。...我自己也按照他的方法解析了一次class文件字节解析 Dalvik 字节可以看这篇dex文件字节解析这篇文章开头还有对应的参考链接,本人按照这两个链接做的 总的来说,dex文件比class文件要复杂得多...基于对象的 API 提供了一种方法,可以表示一个类的事件序列转换为表示同一个类的对象树,也可以反过来,将对象树表示为等价的事件序列。换言之,基于对象的 API 构建在基于事件的 API 之上。

1.2K20
领券