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

反编译Apk得到Java代码

//laichao.googlecode.com/files/jd-gui-0.3.2.linux.i686.tar.gz 步骤: 1.首先找到Android软件安装包中的classes.dex 把.apk...文件改名为.zip,然后解压缩,得到其中的classes.dex文件,它就是java文件编译再通过dx工具打包成的,所以现在我们就用上述提到的2个工具来逆方向导出java源文件 2.把classes.dex...所在目录,运行 dex2jar.bat classes.dex  ,生成classes.dex.dex2jar.jar  3.运行JD-GUI工具(它是绿色无须安装的) 打开上面的jar文件,即可看到源代码...生成程序的源代码和图片、XML配置、语言资源等文件。...三.将反编译完的文件重新打包成apk  很简单,只要输入:      apktood b c:***文件夹(你编译出来文件夹)

2K20

利用apktool查看apk代码

一、首先下载反编译工具包 下载地址   链接:https://pan.baidu.com/s/1CEo93BjAKes-xElp47XlHQ 密码:jyia 1.apktool:由于直接改apk后缀进行解压的话打开的...xml文件会乱码,所以我们使用apktool工具查看apk的xml文件、AndroidManifest.xml和图片等 2.dex2jar:classes.dex转换成jar包 3.jd-gui:查看jar...文件的java代码 二、下载之后,将需要反编译的apk放到apktools同级目录下,并且在apktools下级目录,按住shift+鼠标右键,选择在此处打开命令窗口,之后运行代码  apktool...d yd.apk(你安装包的名字) 三、将apk后缀名改成zip。...之后用解压软件进行解压,得到一个文件如下 这样看到的xml格式是乱码的  所以使用apktool去释放apk才不会乱码 四、将classes.dex打包成jar包 需要用到dex2jar,同样的方法,

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

APK加固之类抽取分析修复

0x01 APK加固前后对比 整体来看一下原始APK包和加固后的APK包结构相关变化 图1所示加固后的APK包变化如下: 新增2个文件夹: assets文件夹中增加3个文件 data dx pk lib..., 反编译出错,错误日志如下: 从图2可以看出反编译时出现了很多错误,我们用IDA对DEX进行反编译查看代码,发现方法指令都被零填充了,反编译后代码显示为nop样式,如图3所示。...图3 我们再来看看APK中的AndroidManifest.xml文件被修改了什么地方?...,这里只贴出部分代码详细的请看工程,代码写得比较粗操,看下思路就行了,有性趣的就慢慢撸吧!...中assets文件夹中的data文件classes.dex放在修复程序同一个目录中,然后运行修复程序。

2K00

Java基础6:代码代码加载顺序

本文主要介绍了三种代码块的特性和使用方法。...代码块:用{}包围的代码 java中的代码块按其位置划分为四种: 局部代码块 位置:局部位置(方法内部) 作用:限定变量的生命周期,尽早释放,节约内存 调用:调用其所在的方法时执行 public class...} } 静态代码块 位置:类成员位置,用static修饰的代码块 作用:对类进行一些初始化 只加载一次,当new多个对象时,只有第一次会调用静态代码块,因为,静态代码块...C(); C c2 = new C(); //结果,静态代码块只会调用一次,类的所有对象共享该代码块 //一般用于类的全局信息初始化 //静态代码块调用 //代码块调用.../details/80061047 关于Java类和包的内容可以在下一节查看: https://blog.csdn.net/a724888/article/details/80069504

45400

【Android 安全】DEX 加密 ( Java 工具开发 | 解压 apk 文件 | 加密生成 dex 文件 | 打包未签名 apk 文件 | 文件解压缩相关代码 )

文章目录 一、解压 apk 文件 二、加密生成 dex 文件 三、打包未签名 apk 文件 四、完整代码示例 五、文件解压缩相关代码 六、执行结果 一、解压 apk 文件 ---- 被解压的 apk 文件位置...// 解压文件 unZip(apkFile, apkUnZipFile) unZip 方法中的代码在最后一节中 ; 二、加密生成 dex 文件 ---- 将 app-debug.apk...") // 压缩打包操作 zip(apkUnZipFile, unSignedApk) 四、完整代码示例 ---- @ExperimentalStdlibApi fun main() {...将 jar 包变成 dex 文件 使用 dx 工具命令 注意 : Windows 命令行命令之前需要加上 "cmd /c " 信息 , Linux ...") // 压缩打包操作 zip(apkUnZipFile, unSignedApk) } 五、文件解压缩相关代码 ---- /** * 删除文件, 如果有目录, 则递归删除 */

1.2K00

【连载】聊聊 APK(二)——Dex 热修复 Classpath

想进大厂,就关注「 程序亦非猿 」 时不时 8:38 推送优质文章,觉得有用,置顶加星标 船长导读:「聊聊 APK」系列由我好基友 Gemini 老师提供 上一篇文章《聊聊 APK —— 直接运行 Dex...热修复 Classloader 参照腾讯开源的 Tinker 和阿里的 DexPatch 的原理,我们知道对于现在对于 java 代码的热修复主要从 DexClassLoader 里面的 dexPathList...Android 提供的 DexClassloader 是按提供的 dex 顺序找的,因此对于 java 代码的热修复变得很简单 —— 只要把想要被修复的 Dex 放到最前面,加载相关的类就好了,Tinker...看图可以看见非常顺利,我们构造了一个“有Bug”的 Dex,假设这个 Dex 目前存在于我们的 apk 里面,那我们如何使用一个新的 Dex 去覆盖我们的 Test.run 方法呢?...构造修复后的 Dex 很简单,首先,在相同的类里面,把我们的代码改了,比如这样,在 Test.java 中: public class Test { public void run() {

58830

关于java中普通代码块、构造代码静态代码

1.普通代码块 public static void main(String[] args) { /*普通代码块: *直接定义在在方法或语句中出现”{普通代码的执行语句}“的就称为普通代码块。...; {   System.out.println("这里是普通代码块B"); } } 执行结果:这里是普通代码块A      这里是普通代码块B 2.静态代码构造代码块 在java...如果类中包含多个静态代码块,那么将按照"先定义的代码先执行,后定义的代码后执行。 ps:1 静态代码块不能存在于任何方法体内。...1"); } { System.out.println("这里是A中的普通代码块2"); } } 执行结果: 这里是静态代码块 这里是普通代码块A 这里是A中的普静态代码块1 这里是A中的普通代码块...1 这里是A中的普通代码块2 这里是普通代码块B 优先级总结:静态代码块>Main()>构造代码

1.3K30

【Android 逆向】APK 文件格式 ( Android 应用安装 | Zip 文件格式 | 使用 Python 代码提取 APK 文件 )

文章目录 一、Android 应用安装 二、APK 文件格式 三、使用 Python 提取 APK 文件 一、Android 应用安装 ---- APK 是 Android 应用的安装文件 , 现在也有...AAB 格式的 , AAB 安装包也可以导出 APK 安装文件 ; 应用安装时 , 会将 APK 安装包拷贝到 /data/app/packageName/ 目录下的 base.apk , 如 : 某应用会将...apk 文件拷贝到 /data/app/com.qidian.QDReader-GTqLCxuMlq6CJtnOVz1LgQ==/base.apk 位置 ; APK 安装目录参考 【Android 逆向...; 三、使用 Python 提取 APK 文件 ---- 使用 Python 提取 APK 文件完整代码 : import os # 如果没有使用 pip install zipfile 安装 import...(apk_path) # 解压目录 , 删除 "app.apk" 的后 4 个字符 ".apk" , 即 "app" out = apk_path[:-4] # 创建目录

1.1K20

Java 常见内存溢出异常代码实现

Java 堆 OutOfMemoryError Java 堆是用来存储对象实例的, 因此如果我们不断地创建对象, 并且保证 GC Root 和创建的对象之间有可达路径以免对象被垃圾回收, 那么当创建的对象过多时...编译运行上述代码后, 会有如下输出: ?...Java 栈 StackOverflowError 我们知道, JVM 的运行时数据区中有一个叫做 虚拟机栈 的内存区域, 此区域的作用是: 每个方法在执行时都会创建一个栈帧, 用于存储局部变量表, 操作数栈...下面是具体的代码: ? 当编译运行上述的代码后, 会输出如下异常信息: ? 方法区内存溢出 ?...运行时常量池溢出 在 Java 1.6 以及之前的 HotSpot JVM 版本时, 有永久代的概念, 即 GC 的分代收集机制是扩展至方法区的.

77230
领券