如何使用Java读取XML响应

时间:2019-03-19 05:36:24

标签: java xml xml-parsing

我正在调用Web服务,并以XML格式获取响应。这是XML响应,

<Response>
    <NO>1</NO>
    <NAME>John Doe</NAME>
</Response>
<Response>
    <NO>2</NO>
    <NAME>Jane Doe</NAME>
</Response>

我正在尝试从每个响应中获取每个数据。我需要获取每个值。

这是我的Java代码,

Document document = DocumentBuilderFactory
                    .newInstance()
                    .newDocumentBuilder()
                    .parse(new InputSource(new StringReader(response.toString())));

            NodeList nodeList = document.getElementsByTagName("Response");
            System.out.println(nodeList.getLength());

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

                if (node.getNodeType() == Node.ELEMENT_NODE) {
                    Element element = (Element) node;

                    NodeList id = (NodeList) element.getElementsByTagName("Response");
                    System.out.println(id);
                    NodeList nodeLists = element.getChildNodes();

                    for (int j = 0; j < nodeLists.getLength(); j++) {
                        Node n = nodeLists.item(j);

                        if (n.getNodeType() == Node.ELEMENT_NODE) {
                            Element name = (Element) n;
                            System.out.println(name.getAttributes().getNamedItem("NO").getNodeValue());
                            System.out.println(name.getAttributes().getNamedItem("NAME").getNodeValue());
                        }
                    }
                }
            }

但是我不能得到我所需要的。什么都没打印。

我需要像这样打印每个值

1
John Doe
2
Jane Doe

基本上,它需要遍历所有<Response>标签并为我提供可用数据。但是我的代码不起作用。

那么有人可以帮助我吗?非常感谢。

2 个答案:

答案 0 :(得分:2)

我从不从事XML解析工作,但是当我在计算机上调试您的代码时,出现了类似的错误,

[Fatal Error] :1:84: The markup in the document following the root element must be well-formed.
Exception in thread "main" org.xml.sax.SAXParseException; lineNumber: 1; columnNumber: 84; The markup in the document following the root element must be well-formed.
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(DOMParser.java:257)
    at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(DocumentBuilderImpl.java:339)
    at com.flotomate.fd.system.etc.OprUtility.main(OprUtility.java:87)

并在StackOverflow上搜索是什么原因导致我发现这个Answer

的错误
  

问题不是添加的根元素。

添加根元素后仍无法修复。所以我遵循与Answer

相同的模式

不确定是否可以优化和定义,但是可以正常工作

String response = " <root>"
                      +"   <Response>  "
                      + "       <NO>1</NO>  "
                      + "       <NAME>John Doe</NAME>  " 
                      + "   </Response>  " 
                      + "   <Response>  "
                      + "       <NO>2</NO>  " 
                      + "       <NAME>Jane Doe</NAME>  " 
                      + "  </Response>  "
                      + "</root>";
    Document document = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(
            new InputSource(new StringReader(response.toString())));

    NodeList nodeList = document.getDocumentElement().getChildNodes();

    for (int i = 0; i < nodeList.getLength(); i++) {
    Node node = nodeList.item(i);
    if (node.getNodeType() == Node.ELEMENT_NODE) {
        Element element = (Element) node;
        if (element.getNodeName().contains("Response")) {
            System.out.println(element.getElementsByTagName("NO").item(0).getTextContent());
            System.out.println(element.getElementsByTagName("NAME").item(0).getTextContent());
        }
    }
}

    //And from this also.....
    for (int i = 0; i < nodeList.getLength(); i++) {
        Element element1 = (Element) nodeList.item(i);
                System.out.println(element.getElementsByTagName("NO").item(0).getTextContent());
                System.out.println(element.getElementsByTagName("NAME").item(0).getTextContent());
    }

输出:

1
John Doe
2
Jane Doe

答案 1 :(得分:1)

NodeList id = (NodeList) element.getElementsByTagName("Response");

这将为您提供标记名称为响应的所有元素的节点列表。但是您在下面的代码中没有使用此节点列表。而是您在element.getChildNodes()上进行迭代。您应该在id上进行迭代,或更具体地说,id是您所需的节点列表。