今天要做一点坏事,需要将某APK反编译出来,修改点东西,然后再回编回去,反编译成功了,但回编时,死活不行。
由于这个APK比较大,有20多m,具体是哪个APK就不说了。
最开始使用“APK改之理”进行反编译,编译了一半,就卡住不动了;
换工具,直接使用 apktool1.5.2 进行反编译:
apktool d C:\*.apk C:\*文件夹
得到想到的SMALI文件和其它文件,但上述命令的输出中,有如何信息,先忽略:
I: Regular manifest package... I: Decoding file-resources... S: Could not decode file, replacing by FALSE value: drawable-hdpi/vxxx.png S: Could not decode file, replacing by FALSE value: drawable-hdpi/vxx2.png ...
apktool.bat b C:\*文件夹
'@*android:style/Theme'. C:\mm\res\values\styles.xml:1886: error: Error retrieving parent for item: No resource found that matches the given name '@*android:style/Theme'. brut.androlib.AndrolibException: brut.androlib.AndrolibException: brut.common.BrutException: could not exec command: [aa pt, p, --min-sdk-version, 7, --target-sdk-version, 7, -F, C:\Users\zhao3546\AppData\Local\Temp\APKTOOL653028490632761398 1.tmp, -0, arsc, -I, C:\Users\zhao3546\apktool\framework\1.apk, -S, C:\mm\res, -M, C:\mm\AndroidManifest.xml] at brut.androlib.Androlib.buildResourcesFull(Androlib.java:358) at brut.androlib.Androlib.buildResources(Androlib.java:283) at brut.androlib.Androlib.build(Androlib.java:206) at brut.androlib.Androlib.build(Androlib.java:176) at brut.apktool.Main.cmdBuild(Main.java:228) at brut.apktool.Main.main(Main.java:79)
上网找了一下,有的说先使用低版本的apktool反编译,再使用高版本的apktool回编,试了不行。
难道就没有其它方法了?APK不就是一个zip包吗?
上面回编时,已经生成了classes.dex了,那我使用WinRAR直接打开之前的APK,将其中的classes.dex使用新生成的classes.dex直接替换掉,
然后给这个APK使用签名工具加上签名,使用签名过的APK测试了一下,在手机上居然可以正常运行,又进一步测试了一下,功能都是ok的。
再将之前反编译出来的某一个SMALI 的加上一个System.out的日志,再重复上面的步骤,得到最新的APK后,再测试一下,成功了。
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream; const-string v1, "11111111" invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
10-24 21:53:26.148: I/System.out(26845): 11111111 10-24 21:53:45.444: I/System.out(26845): 11111111