Mam kompletny dokument XML w ciągu znaków i chciałbym obiektu Document
. Google wyszukuje różnego rodzaju śmieci. Jakie jest najprostsze rozwiązanie? (W Javie 1.5)Jak załadować plik org.w3c.dom.Document z XML w ciągu znaków?
Rozwiązanie Dzięki Matt McMinn, zdecydowałem się na tę realizację. Ma odpowiedni poziom elastyczności wejściowej i wyjątkowej ziarnistości dla mnie. (Dobrze jest wiedzieć, czy błąd pochodzi od zniekształconego XML - SAXException
- lub po prostu złe IO - IOException
.)
public static org.w3c.dom.Document loadXMLFrom(String xml)
throws org.xml.sax.SAXException, java.io.IOException {
return loadXMLFrom(new java.io.ByteArrayInputStream(xml.getBytes()));
}
public static org.w3c.dom.Document loadXMLFrom(java.io.InputStream is)
throws org.xml.sax.SAXException, java.io.IOException {
javax.xml.parsers.DocumentBuilderFactory factory =
javax.xml.parsers.DocumentBuilderFactory.newInstance();
factory.setNamespaceAware(true);
javax.xml.parsers.DocumentBuilder builder = null;
try {
builder = factory.newDocumentBuilder();
}
catch (javax.xml.parsers.ParserConfigurationException ex) {
}
org.w3c.dom.Document doc = builder.parse(is);
is.close();
return doc;
}
Byłoby miło, gdyby można skorygować rozwiązanie. Używanie String.getByptes i InputStream narzucają problemy i18n. Jeden z moich znajomych dostał kod z tego, co jest złe. Na szczęście to odkrywcy wykryli problem. Prawidłowym rozwiązaniem dostarczonym przez erickson jest użycie InputSource. –