4

これは、 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>

では、Sax ContentHandler を使用して CDATA セクションを出力するにはどうすればよいでしょうか?

4

2 に答える 2

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();
于 2008-10-01T13:36:44.873 に答える
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");
于 2010-08-29T08:26:31.100 に答える