java document 编码_Java,XML DocumentBuilder – 在解析时设置编码

我正在尝试保存一个树(扩展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();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值