【发布时间】:2012-12-20 22:58:16
【问题描述】:
在解析 XML 文件时,Stax 会产生错误:
Unicode(0xb) 错误 - 在文档的元素内容中发现无效的 XML 字符 (Unicode: 0xb)。
只需单击下面的链接,其中带有特殊字符“VI”的 xml 行。它不是字母字符:当您尝试将其复制并粘贴到记事本中时,您会得到它作为一些符号。我尝试使用 Stax 解析它。它显示了上述错误。
有人可以给我一个解决方案吗?
提前致谢。
【问题讨论】:
在解析 XML 文件时,Stax 会产生错误:
Unicode(0xb) 错误 - 在文档的元素内容中发现无效的 XML 字符 (Unicode: 0xb)。
只需单击下面的链接,其中带有特殊字符“VI”的 xml 行。它不是字母字符:当您尝试将其复制并粘贴到记事本中时,您会得到它作为一些符号。我尝试使用 Stax 解析它。它显示了上述错误。
有人可以给我一个解决方案吗?
提前致谢。
【问题讨论】:
每当无效的 xml 字符出现在 xml 中时,就会出现这样的错误。当您在记事本++ 中打开它时,它看起来像 VT、SOH、FF,这些都是无效的 xml 字符。我正在使用 xml 1.0 版,并且在通过模式将文本数据输入数据库之前验证文本数据
Pattern p = Pattern.compile("[^\u0009\u000A\u000D\u0020-\uD7FF\uE000-\uFFFD\u10000-\u10FFF]+");
retunContent = p.matcher(retunContent).replaceAll("");
保证xml中不会输入无效的特殊字符
【讨论】:
0xB(垂直制表符)不是 XML 中的有效字符。 ASCII 32(0x20,空格)之前的唯一有效字符是 0x9(制表符)、0xA(回车)和 0xD(换行)。
简而言之,您要解析的不是 XML。
【讨论】:
根据XML W3C Recommendation 0xb is not allowed in an XML file:
字符范围 [2] 字符 ::= #x9 | #xA | #xD | [#x20-#xD7FF] | [#xE000-#xFFFD] | [#x10000-#x10FFFF] /* 任何 Unicode 字符,不包括代理块、FFFE 和 FFFF。 */
严格来说,您的输入文件不是 XML 文件。
【讨论】: