Como saída de uma seção CDATA de um Sax XmlHandler
Pergunta
Esta é uma pergunta acompanhamento das Como caracteres codificar do Oracle para xml?
No meu ambiente aqui eu usar Java para serializar o conjunto de resultados para xml. Eu não tenho acesso ao próprio fluxo de saída, apenas para um org.xml.sax.ContentHandler.
Quando tento caracteres de saída em uma seção CDATA:
Isso acontece basicamente assim:
xmlHandler.startElement(uri, lname, "column", attributes);
String chars = "<![CDATA["+rs.getString(i)+"]]>";
xmlHandler.characters(chars.toCharArray(), 0, chars.length());
xmlHandler.endElement(uri, lname, "column");
fico com esta:
<column><![CDATA[33665]]></column>
Mas eu quero isso:
<column><![CDATA[33665]]></column>
Então, como posso saída de uma seção CDATA com um Sax ContentHandler?
Solução
Ele está sendo escapou porque a função handler.characters é projetado para escapar e a parte <![CDATA[
não é considerado parte do valor.
Você precisa usar os métodos recém-expostas em DefaultHandler2
ou usar a abordagem TransformerHandler
onde você pode definir o CDATA_SECTION_ELEMENTS
chave de saída, que leva uma lista espaços delimitados de nomes de marcas que devem seções de texto sub saída fechados em 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();
Outras dicas
Você deve usar startCDATA()
e endCData()
como delimitadores, i.
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");