用Android Studio构建一个项目(原本是eclipse ADT项目,刚迁移到studio),构建debug版本时正常,构建release版本时报错,错误信息如下:
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:lintVitalAnalyzeRelease'.
> Could not resolve all files for configuration ':app:releaseCompileClasspath'.
> Failed to transform out.aar (project :SDK) to match attributes {artifactType=android-lint-exploded-aar, com.android.build.api.attributes.BuildTypeAttr=release, com.android.build.gradle.internal.attributes.VariantAttr=release, org.gradle.usage=java-api}.
> Execution failed for ExtractAarTransform: D:\**\<项目名>\SDK\build\intermediates\local_aar_for_lint\release\out.aar.
> malformed input off : 26, length : 1
此项目有2个模块:app(application)和SDK(library)
构建环境:gradle和AGP(android gradle plugin)版本均为7.0.2
补充:我还测试过gradle版本为6.7.1、AGP版本为4.2.0时的情况,构建release版本时并不会报错,原因是这个版本的gradle不包含:app:lintVitalAnalyzeRelease这个任务,既然都不存在这个任务,那也就不会产生执行这个任务才会导致的错误。
经过一番搜索、猜测加尝试,发现是libs目录下存在一个名字中带有汉字的jar包,以及在SDK模块中assets目录下存在以汉字命名的子目录,是这些汉字导致了Task :app:lintVitalAnalyzeRelease执行错误。那么只需重命名这些目录和文件即可解决问题。
其实现在的文件基本都用utf-8编码,在文件中包含汉字已经不在需要特别注意编码问题了,但是项目中的目录和文件命名最好还是不要包含汉字,否则容易出现各种问题。
最后再看看这个问题也不是很复杂,但是百度谷歌搜了很久也没找到相关的问题,估计这个问题比较少见,所以特别记录一下以供参考。
在没找到原因之前感觉错误日志啥都没讲,但找到原因后再一看感觉又提示了点东西,我觉得我又可以分析一波了,哈哈哈!
来看上面的日志最后三句,
> Failed to transform out.aar (project :SDK) to match attributes {artifactType=android-lint-exploded-aar, com.android.build.api.attributes.BuildTypeAttr=release, com.android.build.gradle.internal.attributes.VariantAttr=release, org.gradle.usage=java-api}.
> Execution failed for ExtractAarTransform: D:\**\<项目名>\SDK\build\intermediates\local_aar_for_lint\release\out.aar.
> malformed input off : 26, length : 1
大致意思应该是转换out.aar文件发生了错误:当输入out.aar中的某条内容到转换程序中时,在输入了26个字符后输入下一个字符时遇到了畸形输入。那么结合我已经找到的原因,基本就可以猜的八九不离十了:
SDK模块中的libs目录下有个名为“AndroidPrinterSDK2.2_加密.jar”的文件,生成out.aar包后,这个文件在out.aar包中的相对路径为:“libs/AndroidPrinterSDK2.2_加密.jar”,数一下“加”这个汉字索引正好是26,也就是在输入这个汉字时发生了错误。
把这个jar包文件名改了后重新构建了一下,又报了个类似的错误:
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':app:lintVitalAnalyzeRelease'.
> Could not resolve all files for configuration ':app:releaseCompileClasspath'.
> Failed to transform out.aar (project :SDK) to match attributes {artifactType=android-lint-exploded-aar, com.android.build.api.attributes.BuildTypeAttr=release, com.android.build.gradle.internal.attributes.VariantAttr=release, org.gradle.usage=java-api}.
> Execution failed for ExtractAarTransform: D:\**\<项目名>\SDK\build\intermediates\local_aar_for_lint\release\out.aar.
> malformed input off : 7, length : 1
一回生二回熟,那肯定是另一个地方又有个中文名目录或文件啥的。前面说了,SDK模块的assets目录下存在一个以汉字命名的子目录(叫“备份”,当然这个子目录下得有文件,不然只有一个目录并不会被打包到out.aar中),它在out.aar中的相对路径为“assets/备份”。数一下,“备”字索引正好是7,又验证了一遍答案。^_^