Android开发:apk反编译及后续打包教程2022win11(亲测)

该文章分为两部分:第一部分引用三方博客、第二部分为逆向生成apk。

一、第一部分反编译

反编译跟随该作者即可顺利实现,步骤非常详细

Android apk反编译_码点的博客-CSDN博客_android apk反编译学习和开发Android应用有一段时间了,今天写一篇博客总结一下Android的apk文件反编译。我们知道,Android应用开发完成之后,我们最终都会将应用打包成一个apk文件,然后让用户通过手机或者平板电脑下载下来进行安装。正常情况下,Android应用打包成apk之后,就无法再看到开发这个应用时使用的资源文件以及代码了。但是我们通过网上提供了一些工具,还是可以将apk进行反编译的,apk反编译之后,我们就可以...https://blog.csdn.net/qq_31939617/article/details/124610655

二、第二部分逆向

A、将反编译后的文件夹编译成apk

命令 java -jar D:\software\ApkRebuild\apktool_2.6.1.jar b --use-aapt2 -o sing.apk D:\software\ApkRebuild\MMTS


D:\software\ApkRebuild>java -jar apktool_2.6.1.jar b --use-aapt2 -o sing.apk D:\software\ApkRebuild\MMTS
I: Using Apktool 2.6.1
I: Checking whether sources has changed...
I: Smaling smali folder into classes.dex...
I: Checking whether sources has changed...
I: Smaling smali_classes2 folder into classes2.dex...
I: Checking whether sources has changed...
I: Smaling smali_classes3 folder into classes3.dex...
I: Checking whether sources has changed...
I: Smaling smali_classes4 folder into classes4.dex...
I: Checking whether sources has changed...
I: Smaling smali_classes5 folder into classes5.dex...
I: Checking whether resources has changed...
I: Building resources...
I: Copying libs... (/lib)
I: Copying libs... (/kotlin)
I: Copying libs... (/META-INF/services)
I: Building apk file...
I: Copying unknown files/dir...
I: Built apk...

 此时的apk是没有签名的,所以安装不上

B、签名apk

命令 jarsigner -verbose -keystore D:\software\ApkRebuild\testApk\keystore.jks -signedjar sing_sign.apk sing.apk keystore


D:\software\ApkRebuild>jarsigner -verbose -keystore D:\software\ApkRebuild\testApk\keystore.jks -signedjar sing_sign.apk sing.apk keystore
输入密钥库的密码短语:
   正在添加: META-INF/MANIFEST.MF
   正在添加: META-INF/KEYSTORE.SF
   正在添加: META-INF/KEYSTORE.RSA
  正在签名: AndroidManifest.xml
  正在签名: classes.dex
  正在签名: classes2.dex
  正在签名: classes3.dex
  正在签名: classes4.dex
  正在签名: classes5.dex
  正在签名: kotlin/annotation/annotation.kotlin_builtins
  ......
  .....
  ....
  ...
  ..
  .
  jar 已签名。

输入密钥的过程中不会显示在doc窗口,不用怀疑,直接输入即可,输入完成按回车键

 签名文件用自己创建的就可以(不需要apk的原签名文件)

如果安装失败,检查是否已经安装原app。如果检查后仍失败,请自行百度

三、第三部分修改源代码

通过修改smali文件来达到修改源码的目的,因为dex和jar文件都是不能修改的。

如果简单的改个文字或者数字就直接找到类对应的smali文件进行修改即可。

如果需要改逻辑(如:添加点击事件),则可以另外写一个demo,写上我们要实现的逻辑,然后反编译获取到smali文件中对应的smali代码段,粘贴到目标源码中(因为直接写smali太难懂了)。

修改res\values\strings:

修改Activity对应的smali文件:

 

 

 

结束

1) APKtool软件包 及签名tool APKtool软件包有2个程序组成:apktool.jar 和 aapt.exe 另外提供一个批处理文件:apktool.bat,其内容为: java -jar "%~dp0\apktool.jar" %1 %2 %3 %4 %5 %6 %7 %8 %9 运行apktools.jar需要java环境(1.6.0版本以上)。 apktool.jar用于解包,apktool.jar和aapt.exe联合用于打包。 signapk.jar 用于签名。 2) APK文件的解包 下面以解开Contacts.apk为例。首先把Contacts.apk Copy到当前工作目录下(例:Test)。在DOS下打入命令 apktool d Contacts.apk ABC 这里“d”表示要解码。Contacts.apk是要解包的APK文件。ABC是子目录名。所有解包的文件都会放在这个子目录内。 3) APK文件的打包 在DOS下打入命令 apktool b ABC New-Contacts.apk 这里“b”表示要打包 ABC是子目录名,是解包时产生的子目录,用来存放所有解包后的和修改后的文件。 New-Contacts.apk打包后产生的新的APK文件。 4) 签名,不签名安装时可能提示如下错误: Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES] --- 没有签名,可以尝试test证书;签名方法见下面。 Failure [INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES] ---- 已存在签名,但使用证书不对,可以尝试使用其他证书签名。 签名方法:到目录android\build\target\product\security找到证书文件,这里可能会有几种证书,test/shared/platform/media,各种证书使用场景不同,可以自己google一下,因为签名很快而且可任意后续更改签名,可以自己尝试各种不同签名; 这个命令行是使用test证书的例子:java -jar signapk.jar testkey.x509.pem testkey.pk8 YOURAPK.apk YOURAPK_signed.apk YOURAPK_signed.apk就是签完名的apk,去测试一下您重新打包apk吧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值