Я построил приложение на родном языке. Он отлично работает на эмуляторе Android, и теперь я хочу создать APK. Я следовал документации для этого , который можно увидеть здесь Я использую команду
. / Gradlew собрать Выпуск
, чтобы построить APK, но я продолжаю получать ошибку при сборке APK. Я проверил различные вопросы переполнения стека по этой теме, включая этот также этот вопрос github . Я включил строку
android.enableAapt2 = ложь
Файл уровня приложения build.gradle выглядит следующим образом
apply plugin: "com.android.application"
import com.android.build.OutputFile
/** * The react.gradle file registers a task for each build variant (e.g. bundleDebugJsAndAssets * and bundleReleaseJsAndAssets). * These basically call `react-native bundle` with the correct arguments during the Android build * cycle. By default, bundleDebugJsAndAssets is skipped, as in debug/dev mode we prefer to load the * bundle directly from the development server. Below you can see all the possible configurations * and their defaults. If you decide to add a configuration block, make sure to add it before the * `apply from: "../../node_modules/react-native/react.gradle"` line. * * project.ext.react = [ * // the name of the generated asset file containing your JS bundle * bundleAssetName: "index.android.bundle", * * // the entry file for bundle generation * entryFile: "index.android.js", * * // whether to bundle JS and assets in debug mode * bundleInDebug: false, * * // whether to bundle JS and assets in release mode * bundleInRelease: true, * * // whether to bundle JS and assets in another build variant (if configured). * // See http://tools.android.com/tech-docs/new-build-system/user-guide#TOC-Build-Variants
* // The configuration property can be in the following formats * // 'bundleIn${productFlavor}${buildType}' * // 'bundleIn${buildType}' * // bundleInFreeDebug: true, * // bundleInPaidRelease: true, * // bundleInBeta: true, * * // whether to disable dev mode in custom build variants (by default only disabled in release) * // for example: to disable dev mode in the staging build type (if configured) * devDisabledInStaging: true, * // The configuration property can be in the following formats * // 'devDisabledIn${productFlavor}${buildType}' * // 'devDisabledIn${buildType}' * * // the root of your project, i.e. where "package.json" lives * root: "../../", * * // where to put the JS bundle asset in debug mode * jsBundleDirDebug: "$buildDir/intermediates/assets/debug", * * // where to put the JS bundle asset in release mode * jsBundleDirRelease: "$buildDir/intermediates/assets/release", * * // where to put drawable resources / React Native assets, e.g. the ones you use via * // require('./image.png')), in debug mode * resourcesDirDebug: "$buildDir/intermediates/res/merged/debug", * * // where to put drawable resources / React Native assets, e.g. the ones you use via * // require('./image.png')), in release mode * resourcesDirRelease: "$buildDir/intermediates/res/merged/release", * * // by default the gradle tasks are skipped if none of the JS files or assets change; this means * // that we don't look at files in android/ or ios/ to determine whether the tasks are up to * // date; if you have any other folders that you want to ignore for performance reasons (gradle
* // indexes the entire tree), add them here. Alternatively, if you have JS files in android/ * // for example, you might want to remove it from here. * inputExcludes: ["android/**", "ios/**"], *
* // override which node gets called and with what additional arguments * nodeExecutableAndArgs: ["node"], * * // supply additional arguments to the packager * extraPackagerArgs: [] * ]
*/
project.ext.react = [
entryFile: "index.js" ]
apply from: "../../node_modules/react-native/react.gradle"
/** * Set this to true to create two separate APKs instead of one: *
- An APK that only works on ARM devices * - An APK that only works on x86 devices * The advantage is the size of the APK is reduced by about 4MB. * Upload all the APKs to the Play Store and people will download * the correct one based on the CPU architecture of their device. */ def enableSeparateBuildPerCPUArchitecture = false
/** * Run Proguard to shrink the Java bytecode in release builds. */ def enableProguardInReleaseBuilds = false
android {
compileSdkVersion 23
buildToolsVersion "23.0.1"
defaultConfig {
applicationId "com.project"
minSdkVersion 16
targetSdkVersion 22
versionCode 2
versionName "1.0"
ndk {
abiFilters "armeabi-v7a", "x86"
}
}
splits {
abi {
reset()
enable enableSeparateBuildPerCPUArchitecture
universalApk false // If true, also generate a universal APK
include "armeabi-v7a", "x86"
}
}
signingConfigs {
release {
if (project.hasProperty('MYAPP_RELEASE_STORE_FILE')) {
storeFile file(MYAPP_RELEASE_STORE_FILE)
storePassword MYAPP_RELEASE_STORE_PASSWORD
keyAlias MYAPP_RELEASE_KEY_ALIAS
keyPassword MYAPP_RELEASE_KEY_PASSWORD
}
}
}
buildTypes {
release {
minifyEnabled enableProguardInReleaseBuilds
proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro"
}
}
// applicationVariants are e.g. debug, release
applicationVariants.all { variant ->
variant.outputs.each { output ->
// For each separate APK per architecture, set a unique version code as described here:
// http://tools.android.com/tech-docs/new-build-system/user-guide/apk-splits
def versionCodes = ["armeabi-v7a": 1, "x86": 2]
def abi = output.getFilter(OutputFile.ABI)
if (abi != null) { // null for the universal-debug, universal-release variants
output.versionCodeOverride =
versionCodes.get(abi) * 1048576 + defaultConfig.versionCode
}
}
}
productFlavors {
} }
dependencies {
compile project(':react-native-vector-icons')
compile fileTree(include: ['*.jar'], dir: 'libs')
compile 'com.android.support:appcompat-v7:23.0.1'
compile 'com.facebook.react:react-native:+'
// From node_modules
implementation project(':react-native-maps')
implementation(project(':react-native-maps')) {
exclude group: 'com.google.android.gms', module: 'play-services-base'
exclude group: 'com.google.android.gms', module: 'play-services-maps'
}
implementation 'com.google.android.gms:play-services-base:10.2.4'
implementation 'com.google.android.gms:play-services-maps:10.2.4' }
// Run this once to be able to run the application with BUCK // puts all compile dependencies into folder libs for BUCK to use task copyDownloadableDepsToLibs(type: Copy) {
from configurations.compile
into 'libs' }
в моем глобальном файле gradle.properties я также обновил response-native до последней 55.3 на момент написания этой статьи, и я все еще получаю сообщение об ошибке, похожее на это.
Задача: app: processReleaseResources
Не удалось выполнить aapt
com.android.ide.common.process.ProcessException: не удалось выполнить aapt
на com.android.builder.core.AndroidBuilder.processResources (AndroidBuilder.java:796)
в com.android.build.gradle.tasks.ProcessAndroidResources.invokeAaptForSplit (ProcessAndroidResources.java:551)
в com.android.build.gradle.tasks.ProcessAndroidResources.doFullTaskAction (ProcessAndroidResources.java:285)
на com.android.build.gradle.internal.tasks.IncrementalTask.taskAction (IncrementalTask.java:109)
в org.gradle.internal.reflect.JavaMethod.invoke (JavaMethod.java:73)
в org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore $ IncrementalTaskAction.doExecute (DefaultTaskClassInfoStore.java:173)
в org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore $ StandardTaskAction.execute (DefaultTaskClassInfoStore.java:134)
в org.gradle.api.internal.project.taskfactory.DefaultTaskClassInfoStore $ StandardTaskAction.execute (DefaultTaskClassInfoStore.java:121)
в org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter $ 1.run (ExecuteActionsTaskExecuter.java:122)
в org.gradle.internal.progress.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute (DefaultBuildOperationExecutor.java:336)
в org.gradle.internal.progress.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute (DefaultBuildOperationExecutor.java:328)
в org.gradle.internal.progress.DefaultBuildOperationExecutor.execute (DefaultBuildOperationExecutor.java:197)
в org.gradle.internal.progress.DefaultBuildOperationExecutor.run (DefaultBuildOperationExecutor.java:107)
в org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction (ExecuteActionsTaskExecuter.java:111)
в org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions (ExecuteActionsTaskExecuter.java:92)
в org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute (ExecuteActionsTaskExecuter.java:70)
в org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute (SkipUpToDateTaskExecuter.java:63)
в org.gradle.api.internal.tasks.execution.ResolveTaskOutputCachingStateExecuter.execute (ResolveTaskOutputCachingStateExecuter.java:54)
в org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute (ValidatingTaskExecuter.java:58)
в org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute (SkipEmptySourceFilesTaskExecuter.java:88)
в org.gradle.api.internal.tasks.execution.ResolveTaskArtifactStateTaskExecuter.execute (ResolveTaskArtifactStateTaskExecuter.java:52)
в org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute (SkipTaskWithNoActionsExecuter.java:52)
в org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute (SkipOnlyIfTaskExecuter.java:54)в org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute (ExecuteAtMostOnceTaskExecuter.java:43)
в org.gradle.api.internal.tasks.execution.CatchExceptionTaskExecuter.execute (CatchExceptionTaskExecuter.java:34)
в org.gradle.execution.taskgraph.DefaultTaskGraphExecuter $ EventFiringTaskWorker $ 1.run (DefaultTaskGraphExecuter.java:248)
в org.gradle.internal.progress.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute (DefaultBuildOperationExecutor.java:336)
в org.gradle.internal.progress.DefaultBuildOperationExecutor $ RunnableBuildOperationWorker.execute (DefaultBuildOperationExecutor.java:328)
в org.gradle.internal.progress.DefaultBuildOperationExecutor.execute (DefaultBuildOperationExecutor.java:197)
в org.gradle.internal.progress.DefaultBuildOperationExecutor.run (DefaultBuildOperationExecutor.java:107)
в org.gradle.execution.taskgraph.DefaultTaskGraphExecuter $ EventFiringTaskWorker.execute (DefaultTaskGraphExecuter.java:241)
в org.gradle.execution.taskgraph.DefaultTaskGraphExecuter $ EventFiringTaskWorker.execute (DefaultTaskGraphExecuter.java:230)
в org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ TaskExecutorWorker.processTask (DefaultTaskPlanExecutor.java:124)
в org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ TaskExecutorWorker.access $ 200 (DefaultTaskPlanExecutor.java:80)
в org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ TaskExecutorWorker $ 1.execute (DefaultTaskPlanExecutor.java:105)
в org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ TaskExecutorWorker $ 1.execute (DefaultTaskPlanExecutor.java:99)
в org.gradle.execution.taskgraph.DefaultTaskExecutionPlan.execute (DefaultTaskExecutionPlan.java:625)
в org.gradle.execution.taskgraph.DefaultTaskExecutionPlan.executeWithTask (DefaultTaskExecutionPlan.java:580)
в org.gradle.execution.taskgraph.DefaultTaskPlanExecutor $ TaskExecutorWorker.run (DefaultTaskPlanExecutor.java:99)
в org.gradle.internal.concurrent.ExecutorPolicy $ CatchAndRecordFailures.onExecute (ExecutorPolicy.java:63)
в org.gradle.internal.concurrent.ManagedExecutorImpl $ 1.run (ManagedExecutorImpl.java:46)
в org.gradle.internal.concurrent.ThreadFactoryImpl $ ManagedThreadRunnable.run (ThreadFactoryImpl.java:55)
Вызвано: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: ошибка при выполнении процесса /Users/danieltuttle/Library/Android/sdk/build-tools/26.0.2/aapt с аргументами { пакет -f --no-crunch -I /Users/danieltuttle/Library/Android/sdk/platforms/android-23/android.jar -M / Пользователи / danieltuttle / project / code / frontend / traveller-mobile / android / app /build/intermediates/manifests/full/release/AndroidManifest.xml -S / Users / danieltuttle / project / code / frontend / traveller-mobile / android / app / build / промежуточные звенья / res / объединены / release -m -J / Users / danieltuttle / проект / код / внешний интерфейс / мобильный путешественник / Android / приложение / сборка / сгенерированный / источник / r / release -F / пользователи / danieltuttle / проект / код / внешний интерфейс / путешественник мобильный / Android / приложение / сборка / промежуточные звенья /res/release/resources-release.ap_ --custom-package com.project -0 apk --output-text-символы / пользователи / danieltuttle / проект / код / внешний интерфейс / путешественник-мобильный / Android / приложение / сборка / промежуточные звенья / символы / выпуск --no-версия-векторы}
на com.google.common.util.concurrent.AbstractFuture.getDoneValue (AbstractFuture.java:503)
на com.google.common.util.concurrent.AbstractFuture.get (AbstractFuture.java:482)
на com.google.common.util.concurrent.AbstractFuture $ TrustedFuture.get (AbstractFuture.java:79)
на com.android.builder.core.AndroidBuilder.processResources (AndroidBuilder.java:794)
... еще 41Вызвано: com.android.ide.common.process.ProcessException: ошибка при выполнении процесса /Users/danieltuttle/Library/Android/sdk/build-tools/26.0.2/aapt с аргументами {package -f --no-crunch -I /Users/danieltuttle/Library/Android/sdk/platforms/android-23/android.jar -M / Users / danieltuttle / project / code / frontend / traveller-mobile / android / приложение / build / промежуточные звенья / манифесты / полный /release/AndroidManifest.xml -S / Пользователи / danieltuttle / project / code / frontend / traveller-mobile / android / app / build / промежуточные / res / объединены / релиз -m -J / Пользователи / danieltuttle / project / code / frontend / traveller-mobile / android / приложение / сборка / созданная / source / r / release -F / Users / danieltuttle / project / code / frontend / traveller-mobile / android / приложение / build / промежуточные звенья / res / release / resources-release .ap_ --custom-package com.project -0 apk --output-text-символы / пользователи / danieltuttle / проект / код / внешний интерфейс / мобильный-путешественник / android / приложение / сборка / промежуточные звенья / символы / выпуск --no- версия-векторы}
в com.android.build.gradle.internal.process.GradleProcessResult.buildProcessException (GradleProcessResult.java:73)
в com.android.build.gradle.internal.process.GradleProcessResult.assertNormalExitValue (GradleProcessResult.java:48)
на com.android.builder.internal.aapt.AbstractProcessExecutionAapt $ 1.onSuccess (AbstractProcessExecutionAapt.java:78)
в com.android.builder.internal.aapt.AbstractProcessExecutionAapt $ 1.onSuccess (AbstractProcessExecutionAapt.java:74)
на com.google.common.util.concurrent.Futures $ CallbackListener.run (Futures.java:1237)
на com.google.common.util.concurrent.MoreExecutors $ DirectExecutor.execute (MoreExecutors.java:399)
на com.google.common.util.concurrent.AbstractFuture.executeListener (AbstractFuture.java:911)
на com.google.common.util.concurrent.AbstractFuture.complete (AbstractFuture.java:822)
на com.google.common.util.concurrent.AbstractFuture.set (AbstractFuture.java:664)
на com.google.common.util.concurrent.SettableFuture.set (SettableFuture.java:48)
на com.android.build.gradle.internal.process.GradleProcessExecutor $ 1.run (GradleProcessExecutor.java:58)
Вызвано: org.gradle.process.internal.ExecException: обработать 'команду' /Users/danieltuttle/Library/Android/sdk/build-tools/26.0.2/aapt '' завершив с ненулевым значением выхода 1
в org.gradle.process.internal.DefaultExecHandle $ ExecResultImpl.assertNormalExitValue (DefaultExecHandle.java:380)
в com.android.build.gradle.internal.process.GradleProcessResult.assertNormalExitValue (GradleProcessResult.java:46)
... еще 9
FAILURE: сборка не удалась, исключение.
- Что пошло не так:
Не удалось выполнить задачу «: app: processReleaseResources».
Не удалось выполнить aapt
Как правильно решить эту проблему, чтобы я мог успешно создать APK?