2016-09-11 4 views
0

Я пытаюсь декомпилировать и перекомпилировать 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 

ответ

0

Apktool копирует двоичный файл (aapt), который необходимо выполнить во временное местоположение на основе Ja va переменная окружения (TMP_DIR) и удаляет ее после завершения. Это похоже на плохой выбор для использования в системе AWS.

Apktool может быть обновлен, чтобы определить его использование в системах Amazon и поместить двоичный файл в, возможно, домашнюю папку (~), или вы можете вручную загрузить двоичный файл aapt [1] для системы (unix) и использовать параметр --aapt path/to/aapt/binary для предотвращения использования apktool автоматически.

[1] https://github.com/iBotPeaches/Apktool/tree/master/brut.apktool/apktool-lib/src/main/resources/prebuilt/aapt

+0

Благодаря Коннор, к сожалению, я попробовал (по этой ссылке: 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

+0

@MikeL Попробуйте передать полный путь (в том числе aapt) самого двоичного файла. Параметр может вводить в заблуждение, но в настоящее время он полагается на значение, являющееся путем пути к двоичному файлу aapt (не папке). –

+0

См. Редактирование. 10 мин. Назад понял, что это может быть проблемой, и в настоящее время я получаю разрешение denied err = 13 вместо err = 2, и хотя запуск с правами root по-прежнему вызывает эту ошибку. Запуск с файлом aapt в пути вызывает err = 2, поэтому я думаю, что без файла правильный путь. Спасибо за предложения. Я чувствую, что я почти там :) – MikeL