美文网首页
常见异常解决之AAPT: error

常见异常解决之AAPT: error

作者: qiuxintai | 来源:发表于2020-11-12 14:29 被阅读0次

    情形一

    错误日志:

    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="中文&#060;Hello World!&#062;"

    情形三

    前两种情形都很好排查和解决,因为会报到具体的代码上面,基本上只要细心一点,稍微看下就能找到问题所在。还有一种由于加密软件和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

          本文链接:https://www.haomeiwen.com/subject/otzebktx.html