Android 反编译-回编译
- List item
集成 APK
第三方提供一个APK,需要集成到自己的APK 中,并且跳转这个第三方 APK ,有两种方式:
插件化技术
可以参考 :https://www.jianshu.com/p/4318c33bbf61 ,由于 Google Play 封杀了插件化技术,推出了他自己的“官方插件化” .aab
,因此插件化技术不能上 Google Play ,在此不研究这种方式。
反编译-合并-回编译
反编译 APK 是将一个已经编译过的 APK 文件通过工具反编译为可读的源代码文件,这样就能够修改代码,实现对 APK 的二次开发。反编译 APK 的工具有很多,可以使用 JADX、Apktool(https://ibotpeaches.github.io/Apktool/)、dex2jar、jd-gui 等。
反编译 APK 后,可以修改源代码,添加第三方库等,然后使用相应的工具将修改后的源代码重新打包成 APK。需要注意的是,由于 APK 的签名校验机制,如果对 APK 进行了修改,则需要重新签名才能安装和使用。
-
反编译 apk ,获取 apk 的 res 资源,下在 apktool 工具,打开命令行,
apktool d -f [需反编译apk的路径] -o [输出资源路径]
-
反编译获取 *.jar 包
# 参数是 apktool d $1 && mv $1 $1.zip && unzip $1.zip "*.dex" -d $1_dex/ && cd $1_dex/ && d2j-dex2jar *.dex
-
合并资源及 jar 包
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ImSU7TDa-1679903227351)(https://s3-us-west-2.amazonaws.com/secure.notion-static.com/1df98af8-4552-4af6-b149-e1c072c67799/Untitled.png)]
红框的四个需要合并的资源及 manifest 文件。
-
解决冲突及报错
- res 里的 android 库与你工程依赖的 Android 库冲突,需要删除
- manifest 文件里冲突资源需要删除,启动
activity
保留一个。 - 合并 assets 文件和lib 文件。
- 合并的 jar 包及自己的 依赖库有冲突的,选一个一个删除。删除 jar 包的文件方法如下:
-
修改 jar 包的后缀名为 .zip 。
-
解压这个 zip 后删除对应的文件夹或者类。
-
重新打包成 jar 包。进入上面删除后的 文件,打开终端输入以下命令
jar cvf [新jar包名字].jar *
-
-
解决完冲突之后,回编译 apk
apktool b [待编译资源路径] -o [生成 apk 路径]
-
生成 apk 签名(没有签名的 apk 是无法运行的)
apksigner sign —ks [签名文件路径] [待签名apk路径]
详见官方文档:https://developer.android.com/studio/command-line/apksigner?hl=zh-cn
以上这些可以写一个脚本,做打包工具用。