Pregunta

Tengo un documento XML completo en una cadena y me gustaría Document objeto.Google encuentra todo tipo de basura.¿Cuál es la solución más sencilla?(En Java 1.5)

Solución Gracias a Matt McMinn, Me he decidido por esta implementación.Tiene el nivel adecuado de flexibilidad de entrada y granularidad de excepciones para mí.(Es bueno saber si el error se debe a un XML con formato incorrecto. SAXException - o simplemente mala 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;
}
¿Fue útil?

Solución

Esto funciona para mí en Java 1.5: eliminé excepciones específicas para mejorar la legibilidad.

import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import java.io.ByteArrayInputStream;

public Document loadXMLFromString(String xml) throws Exception
{
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

    factory.setNamespaceAware(true);
    DocumentBuilder builder = factory.newDocumentBuilder();

    return builder.parse(new ByteArrayInputStream(xml.getBytes()));
}

Otros consejos

¡Vaya!

Hay un problema potencialmente grave con este código, porque ignora la codificación de caracteres especificada en el String (que es UTF-8 por defecto).Cuando usted llama String.getBytes() la codificación predeterminada de la plataforma se utiliza para codificar caracteres Unicode en bytes.Entonces, el analizador puede pensar que está obteniendo datos UTF-8 cuando en realidad está obteniendo EBCDIC o algo así... ¡no es bonito!

En su lugar, utilice el método de análisis que toma un InputSource, que se puede construir con un Reader, como este:

import java.io.StringReader;
import org.xml.sax.InputSource;
…
        return builder.parse(new InputSource(new StringReader(xml)));

Puede que no parezca gran cosa, pero el desconocimiento de los problemas de codificación de caracteres conduce a una descomposición insidiosa del código similar al año 2000.

Tuve un problema similar, excepto que necesitaba una Lista de Nodos y no un Documento, esto es lo que se me ocurrió.Es prácticamente la misma solución que antes, aumentada para obtener el elemento raíz como NodeList y utilizando la sugerencia de Erickson de usar un InputSource en su lugar para problemas de codificación de caracteres.

private String DOC_ROOT="root";
String xml=getXmlString();
Document xmlDoc=loadXMLFrom(xml);
Element template=xmlDoc.getDocumentElement();
NodeList nodes=xmlDoc.getElementsByTagName(DOC_ROOT);

public static Document loadXMLFrom(String xml) throws Exception {
        InputSource is= new InputSource(new StringReader(xml));
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        factory.setNamespaceAware(true);
        DocumentBuilder builder = null;
        builder = factory.newDocumentBuilder();
        Document doc = builder.parse(is);
        return doc;
    }

Para manipular XML en Java, siempre tiendo a utilizar la API Transformer:

import javax.xml.transform.Source;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMResult;
import javax.xml.transform.stream.StreamSource;

public static Document loadXMLFrom(String xml) throws TransformerException {
    Source source = new StreamSource(new StringReader(xml));
    DOMResult result = new DOMResult();
    TransformerFactory.newInstance().newTransformer().transform(source , result);
    return (Document) result.getNode();
}   
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top