Tenho um documento XML completo em uma string e gostaria de um Document
objeto. O Google encontra todo tipo de lixo. Qual é a solução mais simples? (Em Java 1.5)
Solução Graças a Matt McMinn , decidi por esta implementação. Ele tem o nível certo de flexibilidade de entrada e granularidade de exceção para mim. (É bom saber se o erro veio de XML malformado SAXException
- ou apenas IO inválido - 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;
}
Respostas:
Isso funciona para mim no Java 1.5 - eliminei exceções específicas para facilitar a leitura.
fonte
getBytes()
sem consideração para codificação.return (Document) builder.parse(new ByteArrayInputStream(xml.getBytes()));
??Uau!
Há um problema potencialmente sério com esse código, porque ele ignora a codificação de caracteres especificada no
String
(que é UTF-8 por padrão). Quando você chamaString.getBytes()
a plataforma, a codificação padrão é usada para codificar caracteres Unicode em bytes. Então, o analisador pode pensar que está obtendo dados UTF-8 quando na verdade está obtendo EBCDIC ou algo assim ... não é bonito!Em vez disso, use o método de análise que usa um InputSource, que pode ser construído com um Reader, como este:
Pode não parecer grande coisa, mas a ignorância dos problemas de codificação de caracteres leva a uma podridão de código insidiosa semelhante ao y2k.
fonte
Acabei de ter um problema semelhante, exceto que precisava de uma NodeList e não de um Documento, aqui está o que eu vim. É basicamente a mesma solução de antes, aumentada para obter o elemento raiz como um NodeList e usando a sugestão de Erickson de usar um InputSource em vez de problemas de codificação de caracteres.
fonte
Para manipular XML em Java, sempre costumo usar a API Transformer:
fonte