我想在我的aws服務器上反編譯並重新編譯一個apk。 我正在使用一個apktool,它似乎在我的本地機器上正常工作。在服務器以爲我可以反編譯,但我不能重新編譯回來,因爲我得到這個錯誤:在aws服務器上運行apktool會導致err = 2/err = 13
>> java -jar apktool/apktool.jar b decompiled_apk_folder
I: Using Apktool 2.2.0
I: Checking whether sources has changed...
I: Checking whether resources has changed...
I: Building resources...
Exception in thread "main" brut.androlib.AndrolibException: brut.androlib.AndrolibException: brut.common.BrutException: could not exec: [/tmp/brut_util_Jar_7342825870469849287.tmp, p, --forced-package-id, 127, --min-sdk-version, 16, --target-sdk-version, 21, --version-code, 1, --version-name, 1.1.3, -F, /tmp/APKTOOL5650064046902136421.tmp, -0, arsc, -0, arsc, -I, /root/.local/share/apktool/framework/1.apk, -S, /decompile_apk_folder/res, -M, /decompile_apk_folder/AndroidManifest.xml]
at brut.androlib.Androlib.buildResourcesFull(Androlib.java:473)
at brut.androlib.Androlib.buildResources(Androlib.java:407)
at brut.androlib.Androlib.build(Androlib.java:306)
at brut.androlib.Androlib.build(Androlib.java:263)
at brut.apktool.Main.cmdBuild(Main.java:224)
at brut.apktool.Main.main(Main.java:84)
Caused by: brut.androlib.AndrolibException: brut.common.BrutException: could not exec: [/tmp/brut_util_Jar_7342825870469849287.tmp, p, --forced-package-id, 127, --min-sdk-version, 16, --target-sdk-version, 21, --version-code, 1, --version-name, 1.1.3, -F, /tmp/APKTOOL5650064046902136421.tmp, -0, arsc, -0, arsc, -I, /root/.local/share/apktool/framework/1.apk, -S, /decompile_apk_folder/res, -M, /decompile_apk_folder/AndroidManifest.xml]
at brut.androlib.res.AndrolibResources.aaptPackage(AndrolibResources.java:439)
at brut.androlib.Androlib.buildResourcesFull(Androlib.java:459)
... 5 more
Caused by: brut.common.BrutException: could not exec: [/tmp/brut_util_Jar_7342825870469849287.tmp, p, --forced-package-id, 127, --min-sdk-version, 16, --target-sdk-version, 21, --version-code, 1, --version-name, 1.1.3, -F, /tmp/APKTOOL5650064046902136421.tmp, -0, arsc, -0, arsc, -I, /root/.local/share/apktool/framework/1.apk, -S, /decompile_apk_folder/res, -M, /decompile_apk_folder/AndroidManifest.xml]
at brut.util.OS.exec(OS.java:97)
at brut.androlib.res.AndrolibResources.aaptPackage(AndrolibResources.java:433)
... 6 more
Caused by: java.io.IOException: Cannot run program "/tmp/brut_util_Jar_7342825870469849287.tmp": error=2, No such file or directory
at java.lang.ProcessBuilder.start(ProcessBuilder.java:1047)
at brut.util.OS.exec(OS.java:90)
... 7 more
Caused by: java.io.IOException: error=2, No such file or directory
at java.lang.UNIXProcess.forkAndExec(Native Method)
at java.lang.UNIXProcess.<init>(UNIXProcess.java:187)
at java.lang.ProcessImpl.start(ProcessImpl.java:130)
at java.lang.ProcessBuilder.start(ProcessBuilder.java:1028)
... 8 more
我與編譯工具和AAPT服務器上的Android SDK,以及PATH變量設置正確平臺工具和工具目錄。任何幫助將不勝感激。
編輯
我也嘗試下載一個預置的AAPT和參數提的是:
java -jar apktool/apktool.jar --aapt /absolute/path/to/aapt_dir b decompiled_apk_folder
,但後來我得到許可被拒絕例外,雖然運行的根(須藤蘇 - ):
Caused by: java.io.IOException: Cannot run program "/absolute/path/to/aapt_dir": error=13, Permission denied
at java.lang.ProcessBuilder.start(ProcessBuilder.java:1047)
at brut.util.OS.exec(OS.java:90)
... 7 more
Caused by: java.io.IOException: error=13, Permission denied
at java.lang.UNIXProcess.forkAndExec(Native Method)
at java.lang.UNIXProcess.<init>(UNIXProcess.java:187)
at java.lang.ProcessImpl.start(ProcessImpl.java:130)
at java.lang.ProcessBuilder.start(ProcessBuilder.java:1028)
... 8 more
感謝康納,很遺憾我試了一下(以下鏈接:https://github.com/iBotPeaches/Apktool/issues/997)但不是 「TMP /香檳......」我得到「引起:java.io.IOException:無法運行程序」aapt_dir「:錯誤= 2,沒有這樣的文件或目錄」。也許我運行參數錯誤。我嘗試了「java -jar apktool/apktool.jar --aapt aapt_dir/b decompiled_apk_folder」的所有變體,其中下載的aapt位於aapt_dir文件夾中。 – MikeL
@MikeL嘗試傳遞完整路徑(包括aapt)二進制文件本身。該參數可能會引起誤解,但目前它依賴於作爲aapt二進制文件路徑的值(不是文件夾)。 –
請參閱編輯。 10分鐘前意識到這可能是問題,現在我得到權限拒絕err = 13而不是err = 2,儘管以root身份運行仍然會出現此錯誤。在路徑中運行aapt文件導致err = 2,所以我認爲沒有這個文件是正確的方法。感謝您的建議。我覺得我幾乎在那裏:) – MikeL