Анализируя xml с помощью DOM, DOCTYPE стирается

почему dom с java стирает doctype при редактировании xml?

получил этот xml-файл:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<!DOCTYPE map[ <!ELEMENT map (station*) >
                <!ATTLIST station  id   ID    #REQUIRED> ]>
<favoris>
<station id="5">test1</station>
<station id="6">test1</station>
<station id="8">test1</station>
</favoris> 

моя функция очень проста:

public static void EditStationName(int id, InputStream is, String path, String name) throws ParserConfigurationException, SAXException, IOException, TransformerFactoryConfigurationError, TransformerException{
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();

    DocumentBuilder builder = factory.newDocumentBuilder();
    Document dom = builder.parse(is);

    Element e = dom. getElementById(String.valueOf(id));
    e.setTextContent(name);
    // Write the DOM document to the file
    Transformer xformer = TransformerFactory.newInstance().newTransformer();
    FileOutputStream fos = new FileOutputStream(path);
    Result result = new StreamResult(fos);  
    Source source = new DOMSource(dom);


        xformer.setOutputProperty(
                OutputKeys.STANDALONE,"yes"     
                );

    xformer.transform(source, result);
}

он работает, но тип документа стирается! и я только что получил весь документ, но без части doctype, что важно для меня, потому что это позволяет мне получать по id! как сохранить доктайп? почему он стирает это? Я пробовал много решений с ключами вывода, например или omImpl.createDocumentType, но ни одно из них не сработало ...

спасибо!

14
задан user2864740 7 December 2013 в 04:14
поделиться