常见异常解决之AAPT: error
情形一
错误日志:
D:\android\workspace40\MyApp\app\src\main\res\layout\activity_main.xml:9: AAPT: error: '#ff00000' is incompatible with attribute textColor (attr) reference|color.
XML代码:
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
android:textColor="#ff00000"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
错误原因:
颜色值少了一位,android:textColor="#ff00000"
解决方案:
修改颜色值,android:textColor="#ff000000"
情形二
错误日志:
D:\android\workspace40\MyApp\app\src\main\res\layout\activity_main.xml:12: AAPT: error: not well-formed (invalid token).
XML代码:
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="中文<Hello World!>"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
错误原因:
字符串中含有特殊字符"<"和">",没有进行转义。
解决方案:
对特殊字符转义,android:text="中文<Hello World!>"
情形三
前两种情形都很好排查和解决,因为会报到具体的代码上面,基本上只要细心一点,稍微看下就能找到问题所在。还有一种由于加密软件和AAPT2冲突引起的,非常难以发现。
错误日志:
D:\android\env\.gradle\caches\transforms-2\files-2.1\4f9c7f78c15bb692cf0895b881aafbad\appcompat-1.2.0\res\anim\abc_fade_in.xml:1: AAPT: error: not well-formed (invalid token).
D:\android\env\.gradle\caches\transforms-2\files-2.1\4f9c7f78c15bb692cf0895b881aafbad\appcompat-1.2.0\res\anim\abc_fade_in.xml: AAPT: error: file failed to compile.
错误原因:
我发现只有公司的windows上的AndroidStudio有这个问题,家里的windows和公司的ubuntu上都没有这个问题。最终确认是公司电脑安装有加密软件引起的,appcompat-1.2.0中的文件解压后被加密了,而AAPT2无法识别加密过的文件。这里会有一个很奇怪的现象:直接用文本编辑器打开时,是可以正常看到文件的文本内容的,完全感受不到被加密了,但是只要一编译,它就会报错。我们可以在资源管理器中查看,确认是否加密了,加密的文件一般会有一把小锁的图标。
appcompat-1.2.0资源文件被加密.png
解决方案:
-
方案一:
在gradle.properties中加入:
android.enableAapt2=false
重新编译,就会发现可以正常编译通过了。
注意:
AAPT2已经在新版的AndroidStudio中默认启用了,并且无法禁用,比3.2.x更高的AndroidStudio版本只能采用方案二。采用方案一,必须要使用支持禁用AAPT2的AndroidStudio版本,实测3.2.x及更低版本都是支持的。之前,由于一直无法解决这个问题,自2018年起,我用3.2.1版本长达2年多。每一个项目都要手动去加android.enableAapt2=false,并且还不能将升级到AndroidStudio最新版本,说起来真是一把辛酸泪,万恶的加密软件啊!!! -
方案二:
既然我们知道问题是由于appcompat-1.2.0中的文件解压后被加密了,那就好办了。我们只要将D:\android\env\.gradle\caches\transforms-2\files-2.1\4f9c7f78c15bb692cf0895b881aafbad\appcompat-1.2.0\下面的所有文件,用没有加密过的替换掉就可以了。重新编译,就会发现可以正常编译通过了。
注意:
(1). 直接停用加密软件也可以,但还是要记得删除已被加密过的文件,这样AndroidStudio才会自动重新下载和解压未加密的。否则,由于文件已经存在,不会重新下载和解压,用的还是加密过的,编译仍会报错。
(2). 更新AndroidStudio版本之后,可能会再报一样的问题,要重新替换一下。