XML存在特殊字符导致无法解析,使用CDATA或转译解决难题!!

XML 解析器通常情况下会处理XML文档中的所有文本,由于业务需求无法强制规范数据中的特殊符号,解析器识别特殊字符导致XML格式出现异常,无法正常解析。

不合法的XML字符必须被替换为相应的实体,如果在XML文档中使用类似"<" 的字符, 那么解析器将会出现错误,因为解析器会认为这是一个新元素的开始。

转译字符

处理方式有两种,一用转译符就行字符转译,使解析器正常识别:

&lt;<小于号
&gt;>大于号
&amp;&
&apos;'单引号
&quot;"双引号

CDATA标签

二使用CDATA标签,使参数成为一个整体,不再识别其中的字符:

语法格式:< ! [ CDATA [忽略检查的文本]]>

在CDATA中将文本的内容写入,那么这段文本内容会被忽略检查,无论里面是否包含XML敏感内容,全部被当作普通的文本去看待。例如:

<content>
   <![CDATA[
         <reportNo>9885-LIS</reportNo>
   ]]>  
</content>

当前博客仅供参考!!!