Apk файл не содержит сертификатов
некоторое время назад я загрузил свое приложение в Google Play (когда оно называлось Android Market).
сегодня я обновил приложение, но я удалил предыдущее хранилище ключей и создал новое.
При загрузке он говорит, что APK должен быть подписан теми же сертификатами, что и предыдущая версия:
загрузка не удалась
вы загрузили APK, который подписан с другим сертификатом к вашим предыдущим APKs. Вы должны использовать то же самое сертификат.
ваши существующие APKs подписаны сертификатом(сертификатами) с отпечатком (отпечатками):
[ В SHA1: 89:2Ф:11:Фе:СЕ:Д6:чч:ДФ:65:Е7:76:3Э:ДД:А7:96:4Ф:84:ДД:БА:33 ]
и сертификат(ы), используемый для подписи APK, который вы загрузили, имеет отпечаток(ы):
[ SHA1: 20:26:F4:C1:DF:0F:2B:D9:46:03:FF:AB:07:B1:28:7B:9C:75:44: CC ]
но у меня нет этого сертификата, и я не хочу удалять и повторно публиковать приложение, потому что оно активно пользователи.
Что я могу сделать, чтобы подписать мое приложение с новым сертификатом?
перед загрузкой обновленного приложения убедитесь, что вы увеличили атрибуты android:versionCode и android:versionName в элементе файла манифеста. Кроме того, имя пакета должно быть одинаковым и the .apk должен быть подписан тем же закрытым ключом. Если имя пакета и сертификат подписи не совпадают с именем существующей версии, Market будет считать его новым приложением и не будет предлагать его Пользователям в качестве обновления.
вы подписали с ключом отладки по ошибке?
Итак, во-первых, проверьте, подписали ли вы приложение с ключом отладки по ошибке.
Как проверить, какие ключи подписи были использованы?
соберите информацию из APK
вы можете проверить, с какими сертификатами были подписаны исходный APK и update APK, используя эти команды, используя Java keytool :
это показывает вам подробную информацию о том, как был подписан APK, например:
важные части, чтобы отметить здесь-для каждого APK-являются в SHA1 значение отпечатков пальцев,владелец значение идентификатора, и действующий от/до даты.
если это keytool команда не работает (тег -jarfile опция требует Java 7), Вы можете получить более подробную информацию через :
к сожалению, это не показывает отпечаток SHA1, но показывает личность владельца X. 509 вместе с датами истечения срока действия сертификата. Например:
сравните владельца, SHA1 и значения истечения срока действия между APKs
если владелец/Х. 509 значение идентификатора CN=Android Debug, O=Android, C=US , то вы подписали APK с вашим ключ debug, не оригинальный ключ релиз
если в SHA1 значение отпечатка пальца отличается от исходного и обновления APKs, то вы сделали не используйте один и тот же ключ подписи для обоих APKs
если владелец/Х. 509 значения идентификаторов различны, или даты истечения срока действия сертификата отличаются между двумя APKs, тогда вы сделали не используйте один и тот же ключ подписи для обоих APKs
обратите внимание, что даже если значения Owner/X. 509 идентичны между двумя сертификатами, это не означает, что сертификаты идентичны - если что - то еще не соответствует - например, значения отпечатков пальцев-тогда сертификаты разные.
Поиск оригинальное хранилище ключей, проверьте резервные копии
если два APKs имеют различную информацию сертификата, то вы должны найдите исходное хранилище ключей, т. е. файл с первым значением отпечатка SHA1, которое Google Play (или keytool ) сказали Вы.
поиск по всем файлам хранилища ключей вы можете найти на вашем компьютере, и в любых резервных копий у вас есть, пока у вас есть один с правильным отпечатком SHA1:
просто пресс Enter при запросе пароля - вам не обязательно вводить его, если вы просто хотите быстро проверить значение SHA1.
Я не могу найти оригинальное хранилище в любом месте
если вы не можете найти оригинальное хранилище ключей, вы будете никогда иметь возможность публиковать любые обновления для этого конкретного приложения.
Android упоминает об этом явно на Подписание Заявления страницы:
предупреждение: храните хранилище ключей и закрытый ключ в надежном и безопасном месте и убедитесь, что у вас есть безопасные резервные копии. если вы опубликуете приложение в Google Play, а затем потеряете ключ, с которым вы подписали приложение, вы не сможете публиковать какие-либо обновления для вашего приложения, так как вы всегда должны подписывать все версии вашего приложения с тем же ключом.
после первого выпуска APK все последующие выпуски должны быть подписаны с точно таким же ключом.
могу ли я извлечь оригинальный ключ подписи из оригинального APK?
нет. Это невозможно. APK содержит только общедоступную информацию, а не информацию о вашем частном ключе.
можно ли перейти на новый ключ подписи?
нет. Даже если вы найдете оригинал, вы не можете подписать APK с ключом, то знак следующего обновления с ключами A и B, то знак следующего обновления После что с ключ только Б.
подписание APK (или любого файла JAR) с несколькими ключами-это технически возможно, но Google Play больше не принимает APKs с несколькими подписями.
что я могу сделать?
вам придется создать приложение с новым идентификатором приложения (например, изменить с " com.образец.myapp "to" com.образец.myapp2") и создать новый список в Google Play.
возможно, Вам также придется изменить свой код, чтобы люди могли установить новое приложение, даже если у них установлено старое приложение, например, вам нужно убедиться, что у вас нет конфликтующих поставщиков контента.
вы потеряете существующую базу установки, отзывы и т. д., и придется найти способ заставить ваших существующих клиентов удалить старое приложение и установите новую версию.
еще раз убедитесь, что у вас есть безопасные резервные копии хранилища ключей и паролей, которые вы используете для этой версии.
ничего - Google ясно говорит, что приложение идентифицируется по ключам, используемым для его подписания. Следовательно, если вы потеряли ключи, вам нужно создать новое приложение.
сегодня я столкнулся с той же проблемой, к сожалению, у меня было два псевдонима в моем файле хранилища ключей.
здесь я получу ответ на этот вопрос . После поиска слишком долго, наконец, я могу взломать ключ и пароль для этого . Я забыл свой ключ и псевдоним также файл jks, но, к счастью, я знаю кучу пароля, который я положил в него . но найти правильные комбинации для этого было самой трудной задачей для меня .
появится окно, теперь оно покажет псевдоним ..Если вы файл jks правильный .. щелкните правой кнопкой мыши на псевдониме и нажмите "Просмотр цепочки сертификатов ".. он покажет ключ SHA1 .. сопоставьте этот ключ с ключом tha, который вы получаете во время загрузки apk в google app store .
если он соответствует, то вы с правильным файлом jks и псевдонимом ..
теперь и у меня есть куча паролей к матчу ..
Теперь перейдите к этому scrren, поставьте тот же путь jks .. и пароль (среди пароля, который у вас есть ) поместите любой путь "Файл сертификата"
Если у вас есть предыдущий файл apk с вами(резервное копирование), то используйте jarSigner для извлечения сертификата из этого apk, а затем используйте этот ключ или используйте keytool для клонирования этого сертификата, возможно, это поможет. Полезные ссылки jarsigner docs и keytool docs.
недавно я столкнулся с этой проблемой, попробовав разные способы входа, такие как enable V1 или V2, вошел, изменив имя псевдонима и последнее, что я знаю, что я использую неправильный файл хранилища ключей
Такой вопрос, можно ли установить неподписанный .apk файл, чтобы протестировать на своём телефоне до релиза в маркете? Или нужно, чтобы он обязательно был подписан?
Я пробовал установить не подписанный, но мне пишет "Приложение не установлено".
3,169 18 18 серебряных знаков 42 42 бронзовых знака 543 1 1 золотой знак 6 6 серебряных знаков 18 18 бронзовых знаков Если вам дан исчерпывающий ответ, отметьте его как верный (галка напротив выбранного ответа).- На девайсе уже стоит прога с таким же пакетом, но подписанная другим ключом (обычно возникает такая коллизия, когда разработка ведется на нескольких компах и на каждом из компов генерируется свой debug ключ). Чтобы такого не возникало, имеет смысл расшаривать один и тот же debug ключ между всеми компами/участниками.
- Если android:versionCode в манифесте ниже, чем тот, который уже стоит на девайсе, - это тоже потенциальная проблема. Установщик, правда, обычно только предупреждает о несоответствии версий приложения.
- Если minSdk в манифесте указан выше, чем тот, который стоит в аппарате, система также может отказать в установке.
- Если <uses-feature> тег в манифесте указывает на требуемые аппаратные возможности, которых нет в девайсе, - это тоже повод для отказа в установке.
- Если используются NDK библиотеки, несовпадающие с целевой платформой, также возможны проблемы. Целевых платформ пока что 4: armeabi , armeabi-v7 , mips и x86 - 90% аппаратов это платформа armeabi - процессоры ARM v.6 - откройте APK и загляните в каталог lib - он должен быть либо пустой, либо должен содержать подкаталоги с названиями целевой платформы.
- Возможна версия, что используется нестандартный установщик. В последнее время их развелось как грязи. Имеет смысл всегда пользоваться стоковым установщиком пакетов.
Проверьте разрешено ли у вас на девайсе из непроверенных источников приложения ставить.
Прошли те времена, когда мобильные приложения мужественно игнорировали все ошибки, связанные с SSL, и позволяли перехватывать и модифицировать трафик. Современные приложения, как минимум, проверяют цепочки сертификатов на валидность и принадлежность к достоверному центру сертификации. Мы, пентестеры, ставим перед собой задачу «убедить» приложение, что сертификат надежный с целью выполнения атаки типа «человек посередине» и последующего изменения трафика. В этой статье будут рассмотрены следующие техники обхода проверок SSL-сертификатов в Android:
- Добавление сертификатов в хранилище достоверных сертификатов.
- Перезапись упакованных сертификатов.
- Использование скрипта Frida для обхода проверок SSL-сертификатов.
- Изменение кода проверки сертификата.
Некоторые из вышеуказанных техник - простые, другие – более сложные в реализации. Мы рассмотрим каждый из этих методов без особого углубления в специфические детали.
Зачем нужнаMITM-атака наSSL
Чтобы просматривать и изменять вызовы веб-службы, используемой мобильным приложением, нам понадобится промежуточный прокси сервер для перехвата, созданный при помощи утилит навроде BurpSuite или ZAP. При перехвате SSL-трафика SSL-соединение прерывается на стороне прокси-сервера. Сертификат, отсылаемый прокси-сервером, анализируется мобильным приложением, как если бы прокси был оконечной точкой веб-службы. По умолчанию самоподписанный сертификат, генерируемые утилитами наподобие Burp, не будет принадлежать проверенной достоверной цепочке. Если сертификат нельзя проверить на достоверность, большинство мобильных будут обрывать соединение вместо того, чтобы подключаться и работать в потенциально незащищенном канале. Техники, представленные ниже, предназначены для одной цели – убедить мобильное приложение, что сертификат, отправляемый прокси-сервером, является достоверным.
Техника 1 – Добавление сертификата в хранилище пользовательских сертификатов
Самый простой способ избежать SSL-ошибок – обзавестись валидным и надежным сертификатом. Эта задача решается относительно просто, если вы сможете установить достоверный сертификат на устройство. Если операционная система доверяет вашему центру сертификации, то будет доверять и сертификату, подписанному центром сертификации.
В Android есть два встроенных хранилища сертификатов, которые отслеживают, каким центрам сертификации доверяет операционная система: системное хранилище (хранит предустановленные сертификаты) и пользовательское хранилище (хранит сертификаты, добавленные пользователями).
Сей факт означает, что, если мы имеем дело с приложением, которое работает в Android 6.0 и более ранних версиях, то можно просто добавить сертификат в пользовательское хранилище. Когда приложение пытается проверить достоверность цепочки для нашего сертификата, то обнаружит, что наш центр сертификации связан с достоверным хранилищем и, следовательно, будет доверять нашему сертификату. В более новых версиях приложение не будет доверять хранилищу пользовательских сертификатов. Чтобы решить эту проблему, нужно прописать такой уровень API и версию Android, чтобы приложение стало доверять пользовательским центрам сертификации. Мы будем редактировать атрибут «platformBuildVersionCode» элемента «manifest» в файле AndroidManifest.xml.
В коде выше в строке «platformBuildVersionCode=25» нужно поменять значение 25 на 23, а в строке platformBuildVersionName="7.1.1" значение 7.1.1 на 6.0.
После переупаковки приложения с обновленным файлом AndroidManifest.xml, доверие пользовательским центрам сертификации будет восстановлено.
Если в приложении будет проходить проверку только указанный сертификат, условия для успешного выполнения этой техники выполняются.
Техника 2 – Перезапись упакованного сертификата
Если после установки сертификата в пользовательское хранилище, изменении в настройках версии Android и успешном прохождении проверок при просмотре других ресурсов, защищенных протоколом SSL, все равно возникают ошибки, значит, разработчики внедрили дополнительные условия, которым должны удовлетворять достоверные центры сертификации. Если не забыли, в предыдущей технике внутри тэга trust-anchors добавлялся новый путь к сертификату. Подобный трюк может использоваться разработчиками для защиты приложений от перехвата SSL.
Если в приложении используется индивидуальная цепочка сертификатов, может сработать метод, связанный с перезаписью сертификата. Поскольку в некоторых случаях разработчики могут предусмотреть дополнительные методы для проверки достоверной цепочки, эта техника не гарантирует стопроцентного результата.
Рисунок 1: Перечень сертификатов, используемых приложением Рисунок 1: Перечень сертификатов, используемых приложениемЕсли открыть пакет приложения при помощи, например, APK Studio, то можно сразу увидеть перечень привязанных сертификатов. На картинке выше сертификаты находятся в папке «assets». Замена явно бросающегося в глаза сертификата UniversalRootCA позволит нам подсунуть приложению наш сертификат.
Техника 3 – Подключение к функциям через фреймворк Frida
Если установки собственного сертификата недостаточно для успешного перехвата SSL-трафика, скорее всего, в приложении используются техники навроде SSL pinning или дополнительная SSL-валидация. В этом случае нужно блокировать проверки через непосредственное подключение к соответствующим функциям. Ранее эта техника была доступна для реализации только на устройствах с правами суперпользователя. Однако на данный момент при помощи библиотеки Frida Gadget можно работать с приложением и получить доступ к полному функционалу фреймворка Frida без прав суперпользователя.
Если вы уже выполняли пентесты мобильных приложений, то, вероятно, знакомы с этим фреймворком. Описание всей функциональности Frida выходит за рамки этой статьи, но если говорить в общем, то этот фреймворк позволяет изменять логику работы приложения во время выполнения. Обычно Frida работает как отдельное приложение и требует прав суперпользователя на устройстве. Если у нас нет прав суперпользователя, мы можем инжектировать в пакет приложения динамическую библиотеку Frida Gadget, содержащую большую часть функционала фреймворка Frida. Эта библиотека загружается во время выполнения приложения и позволяет вносить изменения в код.
Чтобы загрузить Frida Gadget, нужно распаковать APK, вставить динамическую библиотеку, отредактировать smali-код так, чтобы динамическая библиотека вызывалась самой первой, а затем переупаковать и установить пакет. Весь этот процесс хорошо задокументирован Джоном Козиракисом (John Kozyrakis). Вначале лучше пройти все этапы вручную, чтобы лучше понять, как работает эта технология. Чтобы сэкономить время, существует утилита - Objection , которая автоматизирует весь вышеупомянутый процесс. Требуется лишь указание целевого пакета, над которым нужно выполнить манипуляции.
C:\ >objection patchapk -s test_app.apk
No architecture specified. Determining it using `adb`.
Detected target device architecture as: armeabi-v7a
Github FridaGadget is v10.6.28, local is v10.6.13. Updating.
Downloading armeabi-v7a library to C:\.objection\android\armeabi-v7a\libfrida-gadget.so.xz.
Unpacking C:\.objection\android\armeabi-v7a\libfrida-gadget.so.xz.
Cleaning up downloaded archives.
Using Gadget version: 10.6.28
Unpacking test_app.apk
App already has android.permission.INTERNET
Reading smali from: C:\Temp\tmp8dxqks1u.apktemp\smali\com/test/app/TestMainActivity.smali
Injecting loadLibrary call at line: 10
Writing patched smali back to: C:\Temp\tmp8dxqks1u.apktemp\smali\com/test/app/TestMainActivity.smali
Creating library path: C:\Temp\tmp8dxqks1u.apktemp\lib\armeabi-v7a
Copying Frida gadget to libs path.
Rebuilding the APK with the frida-gadget loaded.
Built new APK with injected loadLibrary and frida-gadget
Signing new APK.
jar signed.
Signed the new APK
Performing zipalign
Zipaling completed
Copying final apk from C:\Users\cwass\AppData\Local\Temp\tmp8dxqks1u.apktemp.aligned.objection.apk to current directory.
Cleaning up temp files.
После завершения в нашей рабочей директории должен появиться файл «test_app.objection.apk». По умолчанию утилита objection добавляет постфикс «.objection» к имени пакета. Далее мы можем установить этот пакет так же, как и любой другой APK, при помощи команды adb install test_app.objection.apk. После того как измененный пакет установлен на целевом устройстве, во время запуска приложение должно встать на паузу на начальном экране. В этот момент мы можем подключиться к серверу Frida, который отслеживает наше устройство:
[Motorola Moto G (5) Plus::gadget]-> Java.available
true
Alternatively, Objection supports interaction with the listening Frida server by using the ‘explore’ command:
C:\>objection explore
___| |_ |_|___ ___| |_|_|___ ___
| . | . | | | -_| _| _| | . | |
|___|___|_| |___|___|_| |_|___|_|_|
|___|(object)inject(ion) v1.2.2
Runtime Mobile Exploration
by: @leonjza from @sensepost
Теперь вы можете воспользоваться функцией для обхода технологии SSL pinning:
Техника 4 – Реверс-инжиниринг кода верификации сертификата
Возможен такой случай, когда разработчик использует собственные SSL-библиотеки вместо системных для верификации сертификата. В этой ситуации нам нужно распаковать пакет, сконвертировать smali-код в Java-код и найти функции, отвечающие за проверку сертификата.
Если использовать «dex2jar», синтаксис будет следующим:
C:\>d2j-dex2jar.bat "C:\test_app.apk"
dex2jar C:\test_app.apk -> .\test_app-dex2jar.jar
Полученный файл .jar должен быть пригоден для открытия в вашей любимой утилите для исследования Java-приложений (например, JD-GUI).
После того как вы нашли функции, отвечающие за проверку сертификата, можно либо полностью пропатчить код, либо подцепиться к нужной функции при помощи Frida. Чтобы сэкономить время и не пересобирать полностью приложение, эффективнее подцепиться к функциям, отвечающим за проверку сертификата. Шаги, описанные в предыдущей технике, позволят подключиться к приложению, и далее вы можете либо подцепиться к функции при помощи утилит фреймворка Frida, либо при помощи приложения Objection.
Техники, описанные в этой статье, позволяют перехватывать SSL-трафик и обходить некоторые наиболее распространенные защиты, используемые разработчиками. Кроме того, я кратко рассказал об утилите Objection и фреймворке Frida. Обход технологии SSL pinning и других защит лишь небольшая часть возможностей, которые позволяют реализовать эти инструменты.
Надеюсь, мне удалось на доступном языке рассказать о техниках, которые могут быть пригодны для оценки безопасности мобильных Android-приложений и демонстрируют важность наличия нескольких способов проведения подобного рода исследований.
Навигация на странице:
Причины появления
В основном эта проблема появляется с программами, которые устанавливаются не через официальный сервис Google Play, а из сторонних источников и загружаются как отдельные apk файлы. В сервисе же система автоматически проверяет каждый скачиваемый на устройство файл, и заранее может предупредить пользователя, что для его телефона приложение не подходит. В этом случае вообще не будет доступна загрузка программы или игры на смартфон.
Вот основные причины возникновения ошибки при синтаксическом анализе пакета:
- Файл, который вы пытаетесь скачать, загружен не полностью;
- В телефоне установлен запрет на установку приложений из неизвестных источников;
- Версия приложения не соответствует версии операционной системы.
Во всех случаях проблему можно решить разными способами, о которых и пойдет речь дальше.
Сначала нужно определить, в чем же проблема, и почему не устанавливается тот или иной apk файл. Для этого поэтапно проводим все действия, начиная с самых простых.
Разрешаем установку из неизвестных источников
По умолчанию в операционной системе Андроид установка из неизвестных источников запрещена, чтобы пользователь не смог навредить своему смартфону. Дело в том, что сторонние приложения и игры могут содержать вирусы, трояны и прочие зловредные коды.
Вам нужно разрешить установку таких приложений.
-
Для этого заходим в «Настройки» аппарата и выбираем пункт «Параметры безопасности».
Здесь находим вкладку «Неизвестные источники» и ставим галочку, чтобы активировать данный пункт!
Внимание! Действия, описанные выше, могут навредить вашему устройству. Рекомендуем загружать apk только с проверенных сайтов и обязательно каждый файл проверять через антивирус на компьютере, например, Касперского.
Еще лучше загружать apk на сайт «Вирустотал». Он позволяет осуществлять проверки сразу по 50 популярным антивирусам.
И так, теперь проверяем, исчезла ли синтаксическая ошибка или нет. Нет? Тогда идем дальше!
Перезагрузка файла и проверка целостности
Попробуйте загрузить файл из других источников или используйте другой загрузчик для скачивания данных из интернета. Так как apk-приложения — это, по сути, разновидность архива, иногда они не догружаются до конца, в связи с чем и возникают проблемы.
Если после загрузки приложений из других источников возникает та же проблема, переходим к следующему пункту.
Проверка версии приложения
У каждого apk-файла, как и у приложений в Google Play, имеется своя минимальная версия операционной системы, при наличии которой и будет осуществляться инсталляция. Если версия Андроида ниже, чем рекомендуемая версия устанавливаемого apk, то вполне понятно, почему возникает синтаксическая ошибка.
Для решения этой проблемы есть 3 способа:
- Найти версию программы, которая будет соответствовать версии вашего Android;
- Обновить ОС на устройстве до максимальной версии, соответствующей приложению;
- Искусственно изменить требования версии через специальный инструмент.
Думаю, что в первых двух вариантах все понятно. Мы же специально рассмотрим и третий вариант с использованием отдельной программы, которая позволит нам изменить требуемую версию операционной системы и корректно установить apk файл. Это в основном подходит тем пользователям, у кого установлена старая версия ОС.
Редактирование файла программой APK Editor
Для работы требуется программа APK Editor. Она есть в двух версиях. Нужна Pro версия, так как именно в ней активирована функция редактирования нужных нам параметров. Стоимость на данный момент составляет 159 рублей. Это небольшая цена за такой прекрасный пакет инструментов.
APK Editor Pro — это универсальный и мощный редактор apk-файлов. Позволяет не только менять минимальные версии для приложений, но еще:
- удалять лишние рекламные объявления;
- менять фон изображений, макеты, разрешение;
- русифицировать интерфейс и пункты меню;
- поменять текст;
- добавить какие-то свои кнопки и вкладки.
Для простых операций не требуется особых навыков, а вот для сложной модификации приложения уже нужны профессиональные навыки работы с подобными инструментами и знание архитектуры приложений под нашу ОС.
- Зайдите в Google Play и скачайте Pro версию на свой смартфон. Откройте программу.
- Далее кликните по вкладке «Выберите apk-файл» и укажите путь к приложению, которое не устанавливается на вашем смартфоне.
- Нажмите на этом файле и подержите несколько секунд палец, чтобы появилось контекстное меню. В нем выберите пункт «Редактирование ресурсов». Внимание! Здесь может появиться ошибка «Невозможно разобрать apk-файл». Это нормальное явление, которое не влияет на нашу процедуру. Просто проигнорируйте данное оповещение.
- Перед вами появится большое количество строчек и подписей на английском языке, но нужно кликнуть по вкладке «Манифест», которая расположена в правом нижнем углу экрана.
- Ждете, пока система прогрузит все файлы. Появится большой список строк и различных параметров.
- Нужно найти параметр «uses-sdk android:minSdkVersion». Он может быть как в начале списка, так и в середине. Но обычно встречается вначале. Нажмите на него, чтобы появилось меню редактирования. Здесь появится две вкладки, в которых будет написано двухзначное число. Это число и указывает на минимальную версию операционной системы Android, с которой будет работать телефон.
Ниже мы предоставили таблицу, чтобы вы могли понять, на какие именно значения нужно менять данные параметры.
Версия операционной системы | Код (API) | Код версии (название ОС) |
---|---|---|
Android 5.1 | 22 | LOLLIPOP_MR1 |
Android 5.0 | 21 | LOLLIPOP |
Android 4.4W | 20 | KITKAT_WATCH |
Android 4.4 | 19 | KITKAT |
Android 4.3 | 18 | JELLY_BEAN_MR2 |
Android 4.2, 4.2.2 | 17 | JELLY_BEAN_MR1 |
Android 4.1, 4.1.1 | 16 | JELLY_BEAN |
Android 4.0.3, 4.0.4 | 15 | ICE_CREAM_SANDWICH_MR1 |
Android 4.0, 4.0.1, 4.0.2 | 14 | ICE_CREAM_SANDWICH |
Android 3.2 | 13 | HONEYCOMB_MR2 |
Android 3.1.x | 12 | HONEYCOMB_MR1 |
Android 3.0.x | 11 | HONEYCOMB |
Android 2.3.4 Android 2.3.3 | 10 | GINGERBREAD_MR1 |
Android 2.3.2 Android 2.3.1 Android 2.3 | 9 | GINGERBREAD |
Как пользоваться этой таблицей? Например, на смартфоне установлена операционная система 4.2.2, а приложение, которое вы загружаете, требует минимальную версию Android — 5.0. Чтобы apk-файл успешно был установлен на смартфоне, в редакторе необходимо изменить параметры на 17 в обеих строчках. И так можно подстроить любое приложение под любую версию операционной системы. Но учтите, что стабильной работы на очень старых Андроидах никто не гарантирует!
Изменили значения? Отлично! Теперь нажимаете кнопку «Сохранить», после чего система обратно переадресует на экран с другими строчками и параметрами. Здесь в верхнем правом углу еще раз нужно кликнуть по вкладке «Сохранить» и дождаться, пока система заново пересоберет файл и сохранит его.
Процесс сборки файла напрямую зависит от объема информации, которая в нем хранится. Чем больше весит apk-файл, тем дольше будет программа компилировать приложение, поэтому ждите до конца и не думайте, что телефон завис!
В конце появится оповещение о том, что apk-файл сохранен, и рядом будет полный путь этого приложения. Можете попробовать установить его из этого же меню, так как будет вкладка «Установить» или можете проследовать через файловый менеджер к папке с сохранением и попробовать инсталлировать приложение оттуда. Если вы все сделали правильно, то установка будет успешной.
Внимание! Файл сохраняется как дубликат вашего apk, поэтому не путайте их! Старый файл так и будет выдавать синтаксическую ошибку, поэтому нужно осуществлять установку нового, созданного в программе APK Editor Pro.
Дополнительные способы решения проблемы
Есть еще несколько способов, предоставляющих возможность установить приложение или игру из apk, если все перечисленные методы не смогли решить проблему.
- Включаем отладку по USB. В некоторых случаях такой подход позволяет решить проблему, но это не панацея, и шанс не особо велик. Для включения этой опции нужно зайти в «Настройки» своего аппарата и кликнуть по вкладке «О телефоне». Прокрутите полосу вниз, пока не найдете пункт «Номер сборки». Кликните по нему 7 раз, чтобы активировать режим разработчика. Теперь переходите обратно в «Настройки» и прокручиваете еще раз вниз, пока не дойдете по пункта «Меню разработчика». В нем находите пункт «Отладка по USB» и активируете.
- Отключение антивирусов. Иногда установка не осуществляется из-за антивируса, который установлен у вас в смартфоне. Порою сигнатуры, которые подаются антивирусом, ложные, и файл блокируется просто так. Но это единичные случаи. Если действительно уверены, что данный apk-файл — безопасный, отключайте антивирус и попробуйте инсталлировать приложение.
Внимание! Пункты меню в Android могут отличаться, и в некоторых версиях «Отладка по USB» может находиться в других каталогах или вкладках, вызываться другими действиями, но во всех версиях Андроида она присутствует!
То, о чем молчат другие источники
Еще один небольшой совет. Если все описанные способы не помогли, скорее всего, проблема в самом приложении, которое вы пытаетесь установить. Быть может, разработчик «собрал» файл с битыми файлами или ошибся в коде, из-за чего и возникают подобные проблемы.
Обязательно поищите в интернете, удалось ли кому-то из пользователей установить эту программу на свой смартфон или нет. Скорее всего, вас таких много!
Заключение
Мы перечислили основные способы устранения синтаксической ошибки на смартфоне под управлением Андроид, и в 99% случаев один из них точно поможет решить проблему. Но при этом советуем загружать приложения только из Google Play или на сайтах, у которых хорошая репутация (можно понять по отзывам пользователей).
Если же проблема так и не разрешилась, напишите в комментариях свою модель телефона, версию Android и название приложения, которое вы решили установить!
Не удалось установить * .apk на эмулятор устройства-5554: EOF
Я несколько раз перезапускал свой компьютер и Eclipse, а также чистые проекты. Я также пробовал это Почему Android-эмулятор настолько медленный? Как мы можем ускорить разработку эмулятора Android? Чтобы оно было исправлено. Вчера он работал очень хорошо. Теперь это так сладко.
Любое предложение или помощь? спасибо
Я сталкивался с этой проблемой много раз. Попробуйте выполнить каждый из этих шагов после каждого шага, запустив файл APK, если он не работает, перейдите к следующему шагу:
- Запустите его снова. (Просто попробуйте повторить его).
- Project-> Clean (очистить проект и любые проекты, на которые он опирается).
- Щелкните правой кнопкой мыши проект в проводнике пакетов, затем закройте его. Затем закройте Eclipse. Затем снова откройте их.
- То же, что и предыдущий шаг плюс Project-> Clean.
- Перезагрузите AVD.
- Удалите AVD. Затем зайдите в папку, в которой находится AVD в папке Android-Sdk, и удалите что-либо с именем AVD (файл плюс папка). Возможно, вам придется перезагрузить компьютер, чтобы удалить его. Создайте новый AVD.
Выполните следующую команду:
Решение:
- Запустите эмулятор (отдельно) и дождитесь полной загрузки.
- Откройте блокировку клавиатуры.
- Перейдите в Eclipse и запустите приложение.
Причина проблемы: эмулятор Android не загрузил все его библиотеки, которые обрабатывают установку нового приложения, и из-за этого вы запускаете java.io.IOException: EOF
Это вызывало у меня проблему.
Вы можете попробовать следующее:
Когда он показывает красную запись – ошибка, не закрывайте эмулятор – оставьте его как есть и запустите приложение еще раз.
По моим сведениям, есть два пути решения проблемы.
Удалите .apk, который снова регенерируется после компиляции, и снова протестируйте эмулятор.
Удалите эмулятор и создайте новый эмулятор помимо своего приложения.
Я думаю, что это работает … если нет, то, пожалуйста, проверьте свой logCat, который покажет вам фактическую ошибку и попытается ее решить ….
Надеюсь, это вам поможет ………
.apk загружается отлично.
Попробуйте window-> show view-> devices-> view menu-> Сбросить adb и снова запустить приложение.
По-моему, вы должны удалить этот AVD и создать новый для API-7. Это будет нормально работать, если не сообщите мне, я пришлю вам еще несколько решений.
- Удалите apk из эмулятора.
- Попробуйте снова запустить приложение из Eclipse.
- Проверьте версию Минимальной версии Android SDK и попробуйте запустить ее в созданном эмулятором AVD Manager.
Он будет работать определенно …
Просто закройте эмулятор eclipse и avd и перезапустите его. Он отлично работает
Я столкнулся с той же проблемой, но я попытался изменить тайм-аут соединения ADB. Я думаю, что по умолчанию это 5000 мс, и я поменял мой на 10000 мс, чтобы избавиться от этой проблемы. Если вы находитесь в Eclipse, вы можете сделать это, перейдя через Window -> Preferences, а затем в DDMS под Android.
Ни один из них не помог мне, вместо этого я подключил свой телефон через задние USB-концентраторы (раньше я использовал USB-концентраторы), и это помогло мне!
В моем случае я использовал эмулятор размера табуляции (7 ") для тестирования приложения. Но он дал мне« Не удалось установить xxxxx.apk на эмулятор устройства-5554! "И запуск отменен.
Единственным работающим решением для меня был установлен бит размера бит эмулятора (1512 МБ) и размер кучи VM до 36 .
После этого он работал как шарм.
Adb очень сумасшедший, после нескольких попыток я узнал, что у меня было много устройств (эмуляторов и устройств), поэтому я удалил все устройства и снова вернулся к работе
- Не запускать эмулятор Android
- Щелкните правой кнопкой мыши Project> Run As> Android-приложение
И затем эмулятор Android автоматически запускается
Решение заключается в том, что вам нужно изменить значение тайм-аута как минимум на 15000 мс (миллисекунды), так как милли меньше секунд, оно будет в экземпляре .. нет необходимости перезапускать. Мы должны дать некоторое время, чтобы эмулятор загрузил файлы для полного запуска. Это зависит от наших системных конфигураций. Перейдите в windows->perspectives->android->DDMS->timeout до 15000.
Это сработает … измените время, если оно не работает. Увеличьте размер кучи и попытайтесь управлять минимальным уровнем Api.
Я решил проблему, перезапустив Eclipse, затем Project -> build all
Когда это случилось со мной, я решил это, закрыв эмулятор и снова запустив проект.
В отличии от iOS и других закрытых систем, разработчики Android предусмотрели возможность установки разнообразных приложений самостоятельно, без участия Google Play Store и других магазинов контента. Имея на руках .apk файл вы сможете самостоятельно установить платное приложение, при этом не заплатив за него ни копейки.
"Зачем прибегать к самостоятельной установке с помощью .apk файлов?" — спросите вы, а затем, что не все приложения представлены в Google Play Store и к тому же большая часть из них платная и стоит денег. Все приложения для Android имеют расширения .apk — по сути это своеобразный архив, содержимое которого можно просмотреть любым архиватором.
С чего начать?
Первое действие, которое вам необходимо выполнить — это разрешить установку приложений из неизвестных источников, переходим Настройки/Settings -> Приложения/Application Settings и ставим галочку напротив пункта Неизвестные источники/Unknown Sources и нажимаем OK.
1. Установка приложений с помощью файлового менеджера
После этого несложного действия можно скопировать .apk файл на SD карточку вашего телефона. Далее, для установки приложения, вы можете воспользоваться любым файловым менеджером, которые распознают и понимают apk файлы. Для этих целей подойдут ASTRO File Manager [8.90 Мб] или ES File Explorer [4.75 Мб].
2. Установка приложений с помощью менеджера приложений
Кроме того, для упрощения процедуры установки приложений для Android существуют специальные программы — менеджеры приложений. Одна из таких программ — SlideME Mobentoo App Installer [4.63 Мб].
3. Установка приложений с помощью компьютера и USB
Однако самый удобный способ установки приложений для Android с помощью подключения смартфона к компьютеру по USB кабелю. Для этого, вам потребуется программа InstallAPK [0.8 МБ] и драйверы USB [3.13 Мб]. Установите ее на компьютер, не забудьте про драйверы, подключите Ваш смартфон по USB кабелю и дважды щелкните по apk файлу.
4. Другие способы установки приложений для Android
В случае, если вы не хотите устанавливать никаких дополнительных программ, то установить приложение из apk файлов можно старым, дедовским способом. Запустите стандартный браузер Android и введите в адресной строке браузера следующую ссылку и установка запустится автоматически:
Данный способ не очень удобен, и подходит для тех, кто устанавливает программы для Android довольно редко.
Заключение
В данной статье мы постарались описать все известные нам способы установки приложения для Android из apk файлов. В случае, если вы знаете другие способы установки программ — напишите нам о них в комментариях и мы обязательно включим данные способы в эту статью. Оставайтесь с нами.
Читайте также: