我认为没有真正的区别。我更喜欢使用CDATA来处理所有事情,因为我不必关心要逃跑的角色,我唯一需要注意的就是内容中的“]]>”,如果将CDATA开头并将标签关闭成多个片段。
例子(PHP)
<?php
function getXMLContent($content)
{
if
(
(strpos($content, '<') !== false) ||
(strpos($content, '>') !== false) ||
(strpos($content, '&') !== false) ||
(strpos($content, '"') !== false) ||
(strpos($content, '\'') !== false)
)
{
// If value contains ']]>', we need to break it into multiple CDATA tags
return "<![CDATA[". str_replace(']]>', ']]]]><![CDATA[>', $content) ."]]>";
}
else
{
// Value does not contain any special characters which needs to be wrapped/encoded/escaped
return $content;
}
}
echo getXMLContent("Hello little world!");
echo PHP_EOL . PHP_EOL;
echo getXMLContent("This <is> a & hard \" test ' for ]]> XML!");
?>
返回
Hello little world!
<![CDATA[This <is> a & hard " test ' for ]]]]><![CDATA[> XML!]]>
如果你把成XML结构是这样的:
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<test>
<![CDATA[This <is> a & hard " test ' for ]]]]><![CDATA[> XML!]]>
</test>
...保存它到一个文件(如test.xml)和ope ñ它与浏览器,你会看到,浏览器(或任何其他XML应用程序/解析器)会告诉你正确的输出中的字符串:
This <is> a & hard " test ' for ]]> XML!
CDATA对于需要转义的较大字符串也更具网络友好性,因此在大多数情况下,XML文件将通过网络传输时应使用IMO。 – 2014-03-10 20:48:48