我正在尝试保存一个树(扩展JTree),它将
XML文档保存到DOM对象中,并改变了它的结构.
我创建了一个新的文档对象,遍历树以成功检索内容(包括XML文档的原始编码),现在有一个ByteArrayInputStream,它具有正确编码的树内容(XML文档).
问题是当我解析ByteArrayInputStream时,编码自动更改为UTF-8(在XML文档中).
有没有办法防止这种情况,并使用ByteArrayInputStream中提供的正确编码.
值得补充的是,我已经使用了
transformer.setOutputProperty(OutputKeys.ENCODING,encoding)方法检索正确的编码.
任何帮助,将不胜感激.
// Read XML
String xml = "xml"
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse(new InputSource(new StringReader(xml)));
// Append formatting
OutputFormat format = new OutputFormat(document);
if (document.getXmlEncoding() != null) {
format.setEncoding(document.getXmlEncoding());
}
format.setLineWidth(100);
format.setIndenting(true);
format.setIndent(5);
Writer out = new StringWriter();
XMLSerializer serializer = new XMLSerializer(out, format);
serializer.serialize(document);
String result = out.toString();