0

私は XML ファイルを持っていて、それを文字列ではなく XML として表示したいのですが、1 つのクラス構造だけから作成しなかったため、JAXB アンマーシャラーを使用できません。ボディ用のクラスと、保持するクラスを作成しました。この XML フォームを取得するためのオブジェクト:

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<XmlSource>
<XmlConf>
    <hostName>weather.yahooapis.com</hostName>
    <parameters>
        <entry>
            <key>w</key>
            <value>2502265</value>
        </entry>
    </parameters>
    <URLPath>/forecastrss</URLPath>
    <urlProtocol>http</urlProtocol>
</XmlConf>
<XmlConf>
    <hostName>weather.yahooapis.com</hostName>
    <parameters>
        <entry>
            <key>w</key>
            <value>2502265</value>
        </entry>
    </parameters>
    <URLPath>/forecastrss</URLPath>
    <urlProtocol>http</urlProtocol>
</XmlConf>
<XmlConf>
    <hostName>weather.yahooapis.com</hostName>
    <parameters>
        <entry>
            <key>w</key>
            <value>2502265</value>
        </entry>
    </parameters>
    <URLPath>/forecastrss</URLPath>
    <urlProtocol>http</urlProtocol>
</XmlConf>
</XmlSource>

だから、私は次のマーシャリング方法を使用しています:

public void add(String fileName) throws IOException, JAXBException,
            ParserConfigurationException, SAXException, TransformerException {

                XmlConf object;
        this.fileName = fileName; 
        File temp = new File(tempName);
        JAXBContext jaxbContext = JAXBContext.newInstance(XmlConfList.class);
        Marshaller jaxbMarshaller = jaxbContext.createMarshaller();

        jaxbMarshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);

        File source = new File(fileName);
        if (source.exists()) {

            jaxbMarshaller.marshal(object, temp);
            MergeXml merge = new MergeXml();
            merge.mergeXML(true, fileName, tempName, mainTag);
        } else {
            XmlStructure struct = new XmlStructure();
            jaxbMarshaller.marshal(struct, source);
            jaxbMarshaller.marshal(object, temp);
            MergeXml merge = new MergeXml();
            merge.mergeXML(true, fileName, tempName, mainTag);
        }
        temp.delete();
    }

このクラスを使用して、2 つの XML 構造をマージしました。

public class MergeXml {

    private static final String YES = "yes";
    private static final String generalTag = "*";

    /**
     * This method used to merge XML old and new files together
     * 
     * @param condition
     * @throws ParserConfigurationException
     * @throws SAXException
     * @throws IOException
     * @throws TransformerException
     */
    public void mergeXML(boolean condition, String fileName, String tempName, String mainTag)
            throws ParserConfigurationException, SAXException, IOException,
            TransformerException {

        DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
        DocumentBuilder db = null;
        Document doc = null;
        Document doc2 = null;

        db = dbf.newDocumentBuilder();
        doc = db.parse(new File(fileName));
        doc2 = db.parse(new File(tempName));

        NodeList elements = doc.getElementsByTagName(mainTag);

        if (condition == true) {
            NodeList nodeList = doc2.getElementsByTagName(generalTag);

            for (int i = 0; i < nodeList.getLength(); i++) {

                Node node = nodeList.item(i);
                Node childNode = doc.adoptNode(node);

                elements.item(0).appendChild(childNode);
            }

        }

        TransformerFactory tFactory = TransformerFactory.newInstance();
        Transformer transformer = tFactory.newTransformer();
        transformer.setOutputProperty(OutputKeys.INDENT, YES);

        DOMSource source = new DOMSource(doc);
        StreamResult result = new StreamResult(new StringWriter());
        transformer.transform(source, result);

        BufferedWriter output = new BufferedWriter(new FileWriter(fileName));
        String xmlOutput = result.getWriter().toString();
        output.write(xmlOutput);
        output.close();

    }
}

それで、それを非整列化するにはどうすればよいですか?? 私は書くことができません:

JAXBContext jaxbContext = JAXBContext.newInstance(something.class);

私の場合はうまくいかなかったので。

4

1 に答える 1

0

DOM Level 3 Load and Save (LS) APIを使用することをお勧めします: org.w3c.dom.ls.LSSerializer.

コードはhereから取得され、テストされていません。ただし、アイデアは明確なはずです。

    DOMImplementation domImplementation = document.getImplementation();
    if (domImplementation.hasFeature("LS", "3.0")
            && domImplementation.hasFeature("Core", "2.0")) {
        DOMImplementationLS domImplementationLS = (DOMImplementationLS) domImplementation
                .getFeature("LS", "3.0");
        LSSerializer lsSerializer = domImplementationLS
                .createLSSerializer();
        DOMConfiguration domConfiguration = lsSerializer.getDomConfig();
        if (domConfiguration.canSetParameter("format-pretty-print",
                Boolean.TRUE)) {
            lsSerializer.getDomConfig().setParameter("format-pretty-print",
                    Boolean.TRUE);
            LSOutput lsOutput = domImplementationLS.createLSOutput();
            lsOutput.setEncoding("UTF-8");
            StringWriter stringWriter = new StringWriter();
            lsOutput.setCharacterStream(stringWriter);
            lsSerializer.write(document, lsOutput);
            return stringWriter.toString();
        } else {
            throw new RuntimeException(
                    "DOMConfiguration 'format-pretty-print' parameter isn't settable.");
        }
    } else {
        throw new RuntimeException(
                "DOM 3.0 LS and/or DOM 2.0 Core not supported.");
    }
于 2013-06-05T14:28:37.227 に答える