Domanda

Ho un documento XML completo in una stringa e vorrei un Document oggetto.Google gira su tutti i tipi di spazzatura.Qual è la soluzione più semplice?(In Java 1.5)

Soluzione Grazie a Matt McMinn, Ho accettato questa implementazione.Ha il giusto livello di flessibilità di inserimento e di eccezione granularità per me.(E ' bene sapere se l'errore è venuto da XML non valido - SAXException - o solo male, 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;
}
È stato utile?

Soluzione

Questo funziona per me in Java 1.5 - ho spogliato eccezioni specifiche per migliorare la leggibilità.

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()));
}

Altri suggerimenti

Non ci provare!

C'è un grave problema con questo codice, perché ignora il carattere di codifica specificato nell' String (che è UTF-8 per impostazione predefinita).Quando si chiama String.getBytes() la piattaforma di codifica predefinita, viene utilizzato per la codifica Unicode caratteri a byte.Così, il parser può pensare è ottenere dati UTF-8 quando in realtà è sempre EBCDIC o qualcosa del genere... non abbastanza!

Invece, utilizzare il metodo parse che prende un InputSource, che può essere costruita con un Lettore, come questo:

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

Potrebbe non sembrare un grande affare, ma l'ignoranza del carattere di problemi di codifica porta a insidioso codice rot simile a y2k.

Appena avuto un problema simile, tranne che avevo bisogno di una NodeList e non un Documento, ecco cosa mi è venuta.È per lo più la stessa soluzione, come prima, aumentata per ottenere l'elemento radice verso il basso come una NodeList e l'utilizzo di erickson il suggerimento di utilizzare un InputSource, invece, per il carattere di problemi di codifica.

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;
    }

Per manipolare XML in Java, tendo sempre ad utilizzare il Trasformatore API:

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();
}   
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top