data:image/s3,"s3://crabby-images/b1d73/b1d73ff7ba97e2900e573536c7117aacec15f2a0" alt=""
问题
新建一个项目,默认使用最新版的 AGP 和 Gradle,打包构建立马失败!
data:image/s3,"s3://crabby-images/a9cb2/a9cb2959b7fcc785596d9d460a6d23f9665014c9" alt=""
错误日志
Caused by: com.android.builder.errors.EvalIssueException: The option 'android.useNewApkCreator' is deprecated.
java
An exception occurred applying plugin request [id: 'com.android.application', version: '8.3.0']
> Failed to apply plugin 'com.android.internal.application'.
> com.android.builder.errors.EvalIssueException: The option 'android.useNewApkCreator' is deprecated.
The current default is 'true'.
It was removed in version 8.0 of the Android Gradle plugin.
全局搜索,当前项目确实没有配置该属性 android.useNewApkCreator
,这属性到底是哪里来的?
data:image/s3,"s3://crabby-images/e6ae8/e6ae8f231dcfa5dfefaba204d8158cd19e9c52e5" alt=""
解决
我们都知道,project.properties 属性值主要数据来源是 gradle.properties 配置文件。
data:image/s3,"s3://crabby-images/15ff2/15ff20fee3c5b8b69a207a209882cc4a9fa6de52" alt=""
我们通过在 build.gradle 文件输出属性配置,确实是有该配置,并且值是 false
看起来怎么与这两句话意思相反呢?真是差点搞不懂了~
① The current default is 'true'. 【实际输出确是 false】
② It was removed in version 8.0 of the Android Gradle plugin. 【removed 了,为什么输出还有值?】
groovy
val newApkKey = "android.useNewApkCreator"
val containsNewApkKey = project.properties.containsKey(newApkKey)
println("containsNewApkKey:${containsNewApkKey}")
for (p in project.properties) {
println("项目属性:${p.key} = ${p.value}")
}
data:image/s3,"s3://crabby-images/5c3d8/5c3d80c1c4112e9a3ba83ff9151f42f241204009" alt=""
根据上述第二点 ② 如果不是系统内预置,我们确认是否存在某个gradle.properties
文件内配置了该属性,并且这个文件是每个项目都会读取的?
果不其然,通过磁盘全局搜索发现一个醒目了路径下存在这个文件,打开一看正如我所想,注释掉之后再运行不再报错了~
#android.useNewApkCreator=false
这或许是 AS 的默认配置文件吧