本当の違いはないと思います。エスケープする文字を気にする必要がなく、コンテンツの「]]>」だけを気にする必要があるため、すべてに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など)に保存し、ブラウザーで開くと、ブラウザー(または他のXMLアプリケーション/パーサー)に正しい出力文字列が表示されることがわかります。
This < is > a & hard " test ' for ]]> XML!