这是如何将字符从Oracle编码为Xml的后续问题?
在我的环境中,我使用Java将结果集序列化为xml.我无法访问输出流本身,只能访问org.xml.sax.ContentHandler.
当我尝试输出CDATA部分中的字符时:
它基本上是这样的:
xmlHandler.startElement(uri, lname, "column", attributes); String chars = ""; xmlHandler.characters(chars.toCharArray(), 0, chars.length()); xmlHandler.endElement(uri, lname, "column");
我明白了:
<![CDATA[33665]]>
但我想要这个:
那么如何使用Sax ContentHandler输出CDATA部分?
它正在被转义,因为handler.characters函数被设计为转义,并且该部分不被视为值的一部分.
您需要使用新公开的方法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();