XML字符支持
严格意义上来说, XML需要转义的字符只有:
<,>,&,”,©;的转义字符分别如下: < >& " '
但是其实有一些控制字符是不被支持的, 会出现如下报错:
An invalid XML character (Unicode: 0x**) was found in the comment.
这个报错是由于内容中含有不被支持的字符:
这些错误的发生是由于一些不可见的特殊字符的存在,而这些字符对于XMl文件来说又是非法的,所以XML解析器在解析时会发生异常,官方定义了XML的无效字符分为三段:
0x00 - 0x08
0x0b - 0x0c
0x0e - 0x1f
解决方案
最简单的解决方案是替换掉这些字符, 因为这些字符本身都不可见, 所以替换掉也不会有任何影响.
其中java代码为:
string.replaceAll("[\\x00-\\x08\\x0b-\\x0c\\x0e-\\x1f]", "");
也可以在前端就直接替换掉:
string.replace(/[\x00-\x08\x0b-\x0c\x0e-\x1f]/g, '')