有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

Java解析XML并映射到对象

我有一个需要用POJO映射的XML文件。 我的XML如下所示:

<?xml version="1.0" encoding="UTF-8" standalone="no" ?>
<data xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <contentType>Document</contentType>
    <siteName>mySite</siteName>
    <listName>myLib</listName>
    <folderName>docset-folder</folderName>
    <documentSetName>documentSet</documentSetName>
    <fields>
        <field name="META_1">123456789</field>
        <field name="META_2">Someone</field>
        <field name="META_3">Germany</field>
    </fields>
</data>

我的POJO看起来像这样:

public class MetaData implements Serializable {
    private String contentType;   
    private String siteName;
    private String listName;
    private String folderName;
    private String documentSetName;
    private Map<String, Object> fields;
}

我的目标是能够将任何XML映射到任何POJO,为此我找到了如何列出类的成员。 在这个阶段,我有一个允许迭代节点列表的方法

public static Iterable<Node> iterable(final NodeList nodeList) {
    return () -> new Iterator<Node>() {

        private int index = 0;

        @Override
        public boolean hasNext() {
            return index < nodeList.getLength();
        }

        @Override
        public Node next() {
            if (!hasNext())
                throw new NoSuchElementException();
            return nodeList.item(index++);
        }
    };
}

我尝试使用DocumentBuilderFactory的主要方法是:

public static void main(String[] args) throws IOException, SAXException, ParserConfigurationException {
    String path = "src/test/resources/bill.xml";
    DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

    // list the members of the metadata class
    List<Field> fields = Arrays.asList(MetaData.class.getDeclaredFields());


    try {
        dbf.setFeature(XMLConstants.FEATURE_SECURE_PROCESSING, true);
        DocumentBuilder db = dbf.newDocumentBuilder();
        Document doc = db.parse(new File(path));

        doc.getDocumentElement().normalize();

        System.out.println("Root Element :" + doc.getDocumentElement().getNodeName());
        System.out.println("------");
        NodeList list = doc.getElementsByTagName("data");
        iterable(list).forEach(node -> {
            if (node.getNodeType() == Node.ELEMENT_NODE) {

                Element element = (Element) node;

                fields.forEach(field -> {
                    if(element.getAttribute(field.getName()).length() > 0) {
                        System.out.println(element.getAttribute(field.getName()));
                    } else {
                        System.out.print(element.getElementsByTagName(field.getName()).item(0).getNodeName());
                        System.out.println(" - " + element.getElementsByTagName(field.getName()).item(0).getTextContent());
                    }
                });
            }
            // System.out.println(node.getTextContent());
        });
    } catch (ParserConfigurationException | SAXException | IOException e) {
        e.printStackTrace();
    }

}

我在这里只是测试获取XML属性、属性和值。 此代码给出以下结果:

contentType - Document
siteName - mySite
listName - myLib
folderName - docset-folder
documentSetName - documentSet
fields - 
     123456789
     Someone
     Germany

我的问题是:我希望:

contentType - Document
siteName - mySite
listName - myLib
folderName - docset-folder
documentSetName - documentSet
fields - 
META_1 - 123456789
META_2 - Someone
META_3 - Germany

我的目标是能够用元数据对象映射它。此处的字段应添加到以META_1为键、以123456789为值的映射中。我有点困在这里了


共 (1) 个答案

  1. # 1 楼答案

    在我的例子中,我使用XPath解析XML文件,您可以获得如下线程中所示的属性名称和值: XPath getting attribute