Android 反编译入门(基于 Mac)

news2025/1/16 11:15:26

1 反编译基础

1.1 什么是反编译

定义:反编译就是将可执行程序转换为某种形式的高级编程语言的过程。

1.2 APK 文件的构成

首先,我们通过一张图来看看 APK 的整体组成:

可以看到,APK 主要由六个部分组成:

  1. Dex 文件:.class 文件处理后的产物,Android 系统的可执行文件。
  2. Resource :资源文件,主要包括 layoutdrawableanimator,通过 R.XXX.id 来引用。
  3. Assets:资源文件,通过 AssetManager 进行加载。
  4. Libraryso 库存放目录。
  5. META-INFAPK 签名有关的信息。
  6. AndroidManifest.xml:清单文件。

1.3 APK 文件分析工具

分析 APK 我们可以借助 Android Studio 自带的 ApkAnalyzer,想要使用这款工具只需要打开 build ,单击 Analyze APK,选择需要分析的 APK 即可。

1.4 APK 反编译

目前网上比较流行的反编译方式是 apktool + dex2jar + jd-gui 的方式。

1.4.1 安装 apktool 工具

点击链接进入 Apktool 下载地址:Apktool - How to Install (ibotpeaches.github.io)

选择对应的操作系统来安装,这里我们使用的是 mac 系统。mac OS 提供的第一种方式太过复杂,因此我们使用 homebrew 来安装。

在命令行输入以下命令:

brew install apktool   

在安装过程中可能会遇到以下问题:

一、you are using Mac OS 13

这是因为 homebrew 版本过旧导致的,需要升级 homebrew

brew update

二、No developer tools installed

提示缺少 xcode-select 工具,我们按照下方提示输入代码:

xcode-select --install

接下来,我们在命令行输入 apktool ,如果出现以下提示说明安装成功。

但也有可能出现如下提示:

这是因为 JAVA_HOME 没有配置,我们需要在自己的 Mac 中配置 JAVA_HOME

配置 JAVA_HOME

首先,查找 JAVA_HOME 所在路径,在命令行输入如下代码:

/usr/libexec/java_home

然后,在终端输入如下代码:

sudo vim /etc/profile

这样我们就进入到了 vim 模式下的 /etc/profile 文件中,按下 i 进入输入模式,然后在文件中加入以下代码:

JAVA_HOME="/Library/Java/JavaVirtualMachines/zulu-8.jdk/Contents/Home"

export JAVA_HOME

CLASS_PATH="$JAVA_HOME/lib"

PATH=".$PATH:$JAVA_HOME/bin"

然后按下 ESC ,键入 :wq! 强制写入并退出。

最后,我们需要让配置生效。输入以下代码回车即可:

source /etc/profile
2.1.4.2 安装 dex2jar

dex2jar 的安装我们同样使用方便快捷的 homebrew,在命令行输入以下代码来安装 dex2jar

brew install dex2jar

在安装过程中可能会报如下错误:

这是因为 homebrew 未完成 git 配置,因此我们需要键入 brew - v ,执行提示给你的两行代码:

git config --global --add safe.directory /opt/homebrew/Library/Taps/homebrew/homebrew-core

回车后,继续执行

git config --global --add safe.directory /opt/homebrew/Library/Taps/homebrew/homebrew-cask

1.4.3 安装 jd-gui

没错,jd-gui 的安装还是 homebrew

brew install jd-gui

1.4.4 开始反编译

首先,我们找到一个 APK 包**「最好是自己的,主流的 APK 一般都做了加固,看不到反编译的 Dex 文件」**,用 apktool 工具来进行反编译

apktool d app-debug.apk

反编译后会得到一个同名的文件夹,它的内容如下:

接下来,我们根据这个文件夹来生成 dex 文件,键入以下代码:

apktool b app-debug

这样,我们就在 app-debugbuild 目录下生成了 classes.dex 文件。

接下来,我们用 dex2jar 工具将这个 dex 文件转化成一个 jar 包,代码如下:

d2j-dex2jar app-debug/build/apk/classes.dex    

执行上述代码后,在下载文件夹下得到了一个 classes-dex2jar.jar 文件**「应该是生成在 app-debug 的同级目录」

最后,我们使用 JD-GUI 展示反编译的成果。在应用程序页面找到 JD-GUI,按住control 键,单击 JD-GUI,选择打开
「这么做是因为 JD-GUI 不受系统信任」**。

打开过程中,我们可能会碰到如下问题:
[外链图片转存失败,源站可能有防盗]!链机制,建(https://img-EWblog.csdnimg.cn/img_convt/1be7016ed4e7132f726149b5041ee.png2b6)http://image.lovemingming.cloud/image-20221130155929190.png)]
!

这是因为该软件没有适配最先的 Mac 系统,解决方式如下:

首先,在应用程序页面右键 JD-GUI,选择显示包内容

Contents/MacOS/universalJavaApplicationStub.sh 文件的内容替换为 v3.2.0/src/universalJavaApplicationStub 中的内容,保存。

image-20221130160435143

打开,JD-GUI 后,我们将刚刚得到的 classes-dex2jar.jar 文件拖入到程序窗口中就可以完成查看了。

2.1.5 加固方法

为了防止我们的应用程序被反编译,我们需要对 APK 进行加固。常用的方法有三种:

  • 反模拟器:模拟器在运行 apk 时,可以监控到 apk 的各种行为。这种方法就是当监测到运行环境是模拟器时,就停止核心代码的运行。
  • 代码虚拟化:主要思路是自建一个虚拟执行引擎,然后把原生的可执行代码转换成自定义的指令进行虚拟执行。
  • 加密:即部分代码以加密的形式存在。例如,将被保护代码分成多个小段,前面的代码先将后面的代码在内存中解密后再执行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/49392.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

什么值得一个头条?从世界杯看“头条”正确打开方式

“足球皇帝”贝肯鲍尔曾说:“在绿茵场上滚动的不是足球,而是黄金。” 卡塔尔世界杯不仅是球迷的盛宴,也是品牌的盛宴。绿茵场广告屏上,众多品牌纷纷现身。还有部分中国企业通过签约球队和球星等形式露面世界杯,共同挖…

【附源码】计算机毕业设计JAVA紫陶文化传播与学习交流网站

【附源码】计算机毕业设计JAVA紫陶文化传播与学习交流网站 目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术:…

熤星传媒文化:抖音怎么切换到旧版本?

抖音现在也在不断地更新版本,但是很多小伙伴可能想知道一些新版本的功能,就随着了、系统去升级了,但是用着用着发现自己更喜欢旧版本的,那么抖音店铺又怎么去做店铺带货呢?跟着熤星传媒小编来一起看看吧! 帐…

OWASP top10 的介绍

​ OWASP top10 的介绍 2021年版TOP 10产生三个新类别,且进行了一些整合 ​​ A01:失效的访问控制 ​ 从第五位上升称为Web应用程序安全风险最严重的类别,常见的CWE包括:将敏感信息泄露给未经授权的参与者、通过发送的数据泄…

07 CSS04

目标: 1、结构伪类选择器 2、伪元素 3、标准流 4、浮动 5、清除浮动 6、(拓展)BFC介绍 一、结构伪类选择器 1、作用与优势 作用:根据元素在HTML中的结构关系查找元素 优势:减少对于HTML中类的依赖,有…

[附源码]计算机毕业设计springboot家庭整理服务管理系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

【MySQL】 MySQL亿级数据、主从架构,Sharding分片

数据库Mysql 内容管理MySQL填充亿级数据Insert into select存储过程loop insertLoadfile 导入CVS文件MySQL基准测试: sysbench、mysqlslapsysbenchmysqlslapSQL优化分页查询优化慢SQL日志工具mysqldumpslowMySQL主从复制MySQL主从复制 knowledgeMySQL二进制日志log_…

APS生产计划排产降低企业的生产运营成本

企业运营成本是企业管理的关键,也是企业加强管理,提高企业效益的重要途径,在多数企业的发展中,如何更有效地控制企业运营成本将显得极为突出和十分重要。 APS生产计划排产可以从“设备、物料、人力”三方面降低企业的运营成本&…

基于Go语言的网盘开发(GloudDisk)

(记录一下自己做项目的过程) 基于go-zero实现的简易的网盘系统,如果有小伙伴对这个项目感兴趣,可以去网上搜索一些资料。这里推荐一下我学习的来源:【项目实战】基于Go-zero、Xorm的网盘系统_哔哩哔哩_bilibili 确定…

AutoCAD Electrical 2022—项目中新建、添加、删除图纸

右键点击项目—选择新建图纸; 点击快捷图标,新建图形; 弹出对话框,在名称中输入图纸名称; 模板为图框的样式,位置代号,图纸保存的位置; 其他根据需要填写; 填写完点击…

JavaScript -- 02. 变量和数据类型

文章目录变量和数据类型1 数值(Number)1.1 普通数值1.2 其他进制的数字2 大整数(BigInt)3 字符串(String)3.1 基础表示3.2 转义字符3.3 模板字符串4 布尔值(Boolean)5 空值(Null)6 未定义(Undefined)7 符号(Symbol&…

6-2 装载问题(分支限界)

6-2 装载问题(分支限界) 一、问题描述 有一批共个集装箱要装上2艘载重量分别为C1和C2的轮船,其中集装箱i的重量为Wi,且 采用下面的策略可得到最优装载方案: (1)将第一艘轮船尽可能装满; (2)将剩余集装箱装上第二艘轮…

基于rsync daemon 实现 sersync——sersync实现实时数据同步

1 sersync 介绍 sersync类似于inotify,同样用于监控,但它克服了inotify的缺点. inotify最大的不足是会产生重复事件,或者同一个目录下多个文件的操作会产生多个事件,例如,当监控目录中有5个文件时,删除目录…

[附源码]计算机毕业设计springboot考试系统

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

学习C语言的优质网站

1. 初衷 C语言是最原始的操作操作数据结构和算法的一门编程语言,没有高级语言的封装,最能锻炼个人的算法思维和能力。 2. 编程网站推荐 2.1 javatpoint https://www.javatpoint.com/static-in-c 2.2 includehelp https://www.includehelp.com/c/ 2.…

Hadoop学习笔记——HDFS

文章目录一、HDFS概述1.1、HDFS产出背景及定义1.1.1 HDFS产生背景1.1.2 HDFS定义1.2、HDFS优缺点1.2.1、HDFS优点1.2.2、HDFS缺点1.3、HDFS组成架构1.4、HDFS文件块大小1.5、限制二、HDFS的Shell操作2.1、基本语法2.2、命令大全2.3、常用命令实操2.3.1 准备工作2.3.2 上传一、H…

快速复现 实现 facenet-retinaface-pytorch 人脸识别 windows上 使用cpu实现

目录0 前言1 搭建环境与项目2 人脸预测与结果展示0 前言 这一次要复现的是人脸识别中的 facenet-retinaface-pytorch 是在上一次博客的内容上更进一步 快速复现 实现 facenet-pytorch 人脸识别 windows上 使用cpu实现 人脸对比 参考了: Pytorch 利用Facenet和Reti…

10 Deployment:让应用永不宕机

文章目录1. 前言2. 为什么要有deployment 对象?3. 如何使用 YAML 描述 Deployment?3.1 查看 Deployment 的基本信息3.2 命令式创建Deployment 的YAML模板3.2.1 Deployment 的关键字段3.2.1.1 replicas 副本字段3.2.1.2 selector 标签筛选字段3.2.1.3 为什么在 YAML…

JAVA学习-java基础讲义02

java基础讲义02一 进制1.1 进制介绍1.2 二进制1.3 任意进制到十进制转换1.4 十进制到任意进制之间的转换1.5 快速转换法1.6 有符号数据表示法二 Java变量和数据类型1.1 变量概述1.2 数据类型1.3 变量定义三 Java数据类型转换3.1 数据类型转换概述3.2 数据类型转换之自动类型转换…

使用自己的数据集测试Unbiased Mean Teacher for Cross-domain Object Detection

要复现Unbiased Mean Teacher for Cross-domain Object Detection(UMT),首先要正确运行CycleGAN。 1. CycleGAN CycleGAN的github链接:https://github.com/junyanz/pytorch-CycleGAN-and-pix2pix 1.1 CycleGAN环境配置 git cl…