0

对于下面的消息,我的解析代码是给:name #text value.

为什么要恢复这个记录?

信息:

<emp>
<emp_name>david</emp-name>
<emp-no>123</emp-no>
</emp>

代码:

final Document doc = parser.loadXml(message);
doc.getDocumentElement().normalize();
NodeList nodeList = doc.getDocumentElement().getChildNodes();
public Map<String, String> getElementKeyValue(NodeList nodeList) {
  Map<String, String> elements = new HashMap<String, String>();
  if (nodeList != null && nodeList.getLength() > 0) {
    for (int i = 0; i < nodeList.getLength(); i++) {
      Node node = nodeList.item(i); // Take the node from the list
      NodeList valueNode = node.getChildNodes(); // get the children // of the node
      String value = (valueNode.item(0) != null) ? valueNode.item(0)
                            .getNodeValue() : "";
      System.out.println("name " + node.getNodeName() + "  value "
                            + value);
      elements.put(node.getNodeName(), value);
    }
  }
  return elements;
}
4

1 回答 1

1

输出name #text value代表标签之间的文本节点。为了避免在上面的代码中出现这种情况,可以使用 和 方法来代替getElementsByTagName("emp_name")getElementsByTagName("emp-no")备选方案:在 XSD 中为这些元素指定相应的空白设置。

于 2014-05-12T13:10:39.550 回答