常见异常解决之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代码:

    

错误原因:

颜色值少了一位,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代码:

    

错误原因:

字符串中含有特殊字符"<"和">",没有进行转义。

解决方案:

对特殊字符转义,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版本之后,可能会再报一样的问题,要重新替换一下。

你可能感兴趣的:(常见异常解决之AAPT: error)