Как загрузить org.w3c.dom.Document из XML в строке?

голоса
96

У меня есть полный текст документа XML в строке и хотели бы Documentобъект. Google превращает все виды мусора. Что такое простое решение? (В Java 1.5)

Решение Благодаря Matt McMinn , я остановился на этой реализации. Он имеет необходимый уровень гибкости ввода и исключения зернистости для меня. (Это хорошо , чтобы знать , если ошибка пришла от некорректного XML - SAXException- или просто плохо 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;
}
Задан 28/08/2008 в 21:03
источник пользователем
На других языках...                            


4 ответов

голоса
137

Вау там!

Там это потенциально серьезная проблема с этим кодом, потому что она игнорирует кодировку , указанную в String(который является UTF-8 по умолчанию). При вызове String.getBytes()кодировка платформы по умолчанию используется для кодирования символов Unicode в байты. Таким образом, анализатор может думать , что получает данные UTF-8 , когда на самом деле это становится EBCDIC или что - то ... не красивая!

Вместо этого используйте метод синтаксического анализа, который принимает InputSource, которая может быть построена с ридером, как это:

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

Это может показаться не таким большим делом, но незнание вопросов кодирования символов приводит к коварной кода гнили сродни Y2K.

Ответил 29/08/2008 в 00:16
источник пользователем

голоса
71

Это работает для меня в Java 1.5 - Я разделся конкретные исключения для удобства чтения.

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()));
}
Ответил 28/08/2008 в 21:11
источник пользователем

голоса
9

Просто была аналогичная проблема, за исключением того, я нуждался в NodeList, а не документ, вот что я придумал. Это в основном такое же решение, как и прежде, пополнена, чтобы получить корневой элемент вниз, как NodeList и используя предложение Эриксона использования в InputSource вместо по вопросам кодирования символов.

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;
    }
Ответил 05/09/2008 в 16:57
источник пользователем

голоса
1

Для того, чтобы манипулировать XML в Java, я всегда предпочитаю использовать трансформатор 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();
}   
Ответил 05/08/2014 в 12:01
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more