質問

これは 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セクションを出力するにはどうすればよいですか?

役に立ちましたか?

解決

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();

他のヒント

区切り文字として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");
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top