我正在使用 StAX 读取 XML 文件,但遇到了像 žćčšđ 这样的字符的问题。 代码几乎与 SAX 中的相同,但我没有遇到那种问题。
这是xml文件的一部分
<?xml version = "1.0" encoding="UTF-8" ?>
<Autor>
<Id>1</Id>
<Meno>Jano Žiška</Meno>
<Email>dfdsfsfdsdf@gmail.com</Email>
<tel_cislo typ="mobil">0944564685</tel_cislo>
<plat>500</plat>
</Autor>
Java
public static void main(String[] args) {
try {
XMLInputFactory f = XMLInputFactory.newInstance();
XMLStreamReader r = f.createXMLStreamReader(new FileReader(SUBOR));
}
....
if (r.getLocalName().equals(ELEMENT_MENO) == true) {
String v = r.getElementText();
System.out.println("meno:\t\t\t " + v);
}
我如何在 java 中指定编码? 谢谢
最佳答案
除非您有非常好的理由,否则您应该始终将二进制 流与 XML (InputStream/OutputStream) 一起使用,而不是字符流 (Reader/Writer)。使用字符流有破坏 xml 的风险(如 OP 的原始代码所示)。
XMLStreamReader r = f.createXMLStreamReader(new FileInputStream( SUBOR ));
关于java - 在 Java StAX 解析器中编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16222202/