这是How to encode characters from Oracle to 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><![CDATA[33665]]></column>
但我想要这个:
<column><![CDATA[33665]]></column>
那么如何输出带有Sax ContentHandler的CDATA部分?
答案 0 :(得分:5)
它被转义,因为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();
答案 1 :(得分:3)
您应该使用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");