سؤال

وهذا هو السؤال متابعة من كيفية ترميز الأحرف من أوراكل ل أكس؟

في بيئتي هنا يمكنني استخدام جافا لتسلسل مجموعة النتائج إلى 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>

ولكن كيف يمكنني إخراج قسم 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