Как вывести раздел CDATA из Sax XmlHandler

Это дополнительный вопрос Как кодировать символы из Oracle в Xml?

Здесь я использую Java для сериализации набора результатов в xml. У меня нет доступа к самому потоку вывода, только к org.xml.sax.ContentHandler.

Когда я пытаюсь вывести символы в разделе CDATA:

В основном это происходит так:

xmlHandler.startElement(uri, lname, "column", attributes);
String chars = "<![CDATA["+rs.getString(i)+"]]>";
xmlHandler.characters(chars.toCharArray(), 0, chars.length());
xmlHandler.endElement(uri, lname, "column");

Я получаю это:

<column>&lt;![CDATA[33665]]&gt;</column>

Но я хочу вот это:

<column><![CDATA[33665]]></column>

Итак, как я могу вывести раздел CDATA с помощью Sax ContentHandler?

Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
4
0
9 130
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Он экранируется, потому что функция handler.characters предназначена для экранирования, а часть <![CDATA[ не считается частью значения.

Вам нужно использовать недавно представленные методы в DefaultHandler2 или использовать подход TransformerHandler, где вы можете установить выходной ключ CDATA_SECTION_ELEMENTS, который принимает список имен тегов, разделенных пробелами, которые должны выводить разделы подтекста, заключенные в CDATA.

StreamResult streamResult = new StreamResult(out);
SAXTransformerFactory tf = (SAXTransformerFactory) SAXTransformerFactory.newInstance();
TransformerHandler hd = tf.newTransformerHandler();
Transformer serializer = hd.getTransformer();
serializer.setOutputProperty(OutputKeys.CDATA_SECTION_ELEMENTS, "column");
hd.setResult(streamResult);
hd.startDocument();
hd.startElement("","","column",atts);
hd.characters(asdf,0, asdf.length());
hd.endElement("","","column");
hd.endDocument();

Что вы имеете в виду под «... DefaultHandler2 или же используйте TransformerHandler», как я могу использовать методы DefaultHandler2 для вывода тегов CData при сериализации XML. Я уже использую в своем коде функции document.createCDATASection(...). Есть ли способ вывести теги CDATA без использования свойства CDATA_SECTION_ELEMENTS?

lanoxx 25.04.2014 11:11

В качестве разделителей следует использовать startCDATA() и endCData(), т.е.

xmlHandler.startElement(uri, lname, "column", attributes);
xmlHandler.startCDATA();
String chars = rs.getString(i);
xmlHandler.characters(chars.toCharArray(), 0, chars.length());
xmlHandler.endCDATA();
xmlHandler.endElement(uri, lname, "column");

Другие вопросы по теме