Я пытаюсь декомпилировать и перекомпилировать apk на моем сервере aws. Я использую apktool для этого и, кажется, правильно работает на моей локальной машине. На сервере думали, что я могу декомпилировать, но я не могу перекомпилировать его обратно, как я получаю эту ошибку:Запуск apktool на сервере aws вызывает 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
У меня есть Android SDK на сервере с автоматической сборки и AAPT, а переменная PATH правильно установлен с каталогами инструментов и инструментов. Любая помощь будет оценена по достоинству.
EDIT
Я также попытался загрузки скомпилированную AAPT и упоминая его в качестве параметра:
java -jar apktool/apktool.jar --aapt /absolute/path/to/aapt_dir b decompiled_apk_folder
, но потом я получил разрешение отказано исключение, хотя работает как корневой (SUDO су -):
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/брют ..." Я получаю «Caused by: 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 мин. Назад понял, что это может быть проблемой, и в настоящее время я получаю разрешение denied err = 13 вместо err = 2, и хотя запуск с правами root по-прежнему вызывает эту ошибку. Запуск с файлом aapt в пути вызывает err = 2, поэтому я думаю, что без файла правильный путь. Спасибо за предложения. Я чувствую, что я почти там :) – MikeL