gpt4 book ai didi

Java, XML DocumentBuilder - 解析时设置编码

转载 作者:数据小太阳 更新时间:2023-10-29 01:55:07 27 4
gpt4 key购买 nike

我正在尝试将包含 XML 文档的树(扩展 JTree)保存到已更改其结构的 DOM 对象

我已经创建了一个新的文档对象,遍历树并成功检索了内容(包括 XML 文档的原始编码),现在有一个 ByteArrayInputStream,它具有正确编码的树内容(XML 文档)。

问题是当我解析 ByteArrayInputStream 时,编码自动更改为 UTF-8(在 XML 文档中)。

有没有办法防止这种情况并使用 ByteArrayInputStream 中提供的正确编码。

还值得补充的是,我已经使用过
transformer.setOutputProperty(OutputKeys.ENCODING, encoding) 方法来检索正确的编码。

如有任何帮助,我们将不胜感激。

最佳答案

这是一个更新的答案,因为 OutputFormat 已被弃用:

TransformerFactory tf = TransformerFactory.newInstance();
Transformer transformer = tf.newTransformer();
transformer.setOutputProperty(OutputKeys.ENCODING, "ISO-8859-1");

StringWriter writer = new StringWriter();
transformer.transform(new DOMSource(document), new StreamResult(writer));
String output = writer.getBuffer().toString().replaceAll("\n|\r", "");

第二部分将 XML 文档作为字符串返回

关于Java, XML DocumentBuilder - 解析时设置编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3578395/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com