CDATA是Character Data的缩写,用于告诉XML解析器将之间的内容视为纯文本,不解析特殊字符。例如description标签内可直接使用

在 XML 中,CDATA 是一种用来包裹文本数据的方式,让解析器将其中的内容视为纯字符数据,而不是标记或特殊符号。当你需要包含大量特殊字符(比如小于号 、与号 & 等)而不想逐个使用实体引用时,CDATA 就非常有用。
什么是 CDATA?
CDATA 是 "Character Data" 的缩写,它的作用是告诉 XML 解析器:从 开始,到 ]]> 结束之间的所有内容都应被当作原始文本处理,不进行语法解析。
例如:
在这个例子中, 和 & 不会被当作 XML 标记的一部分,也不会引发解析错误。
XML 中的特殊字符问题
XML 只允许几个预定义的实体来表示特殊字符:
- > 表示 >
- & 表示 &
- " 表示 "
- ' 表示 '
如果直接写这些符号,尤其是
使用 CDATA 处理特殊字符的建议
当文本中包含较多特殊字符,特别是代码、脚本或富文本内容时,使用 CDATA 更简洁高效。
适用场景包括:
- 嵌入 JavaScript 或 CSS 代码
- 包含数学表达式或编程语句
- 传输含有 HTML 标签的描述字段
示例:
5) { alert("Hello"); }]]>
这样就不需要把每个 & 写成 &,每个
注意事项和限制
虽然 CDATA 很方便,但也有几点需要注意:
- CDATA 块不能嵌套。也就是说,不能在一个 CDATA 中再写
- 如果文本本身包含 ,就会提前结束 CDATA 块,造成错误
- 某些情况下,接收方系统可能对 CDATA 支持不完整,需确认兼容性
对于只有一两个特殊字符的情况,使用实体引用更简单安全;对于大段含特殊字符的文本,优先考虑 CDATA。
基本上就这些。合理使用 CDATA 能有效避免 XML 特殊字符带来的解析问题,让数据更清晰、更易维护。










