对于下面的消息,我的解析代码正在提供: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;
}
答案 0 :(得分:1)
输出name #text value
代表标签之间的文本节点。为避免在上面的代码中,可以使用方法getElementsByTagName("emp_name")
和getElementsByTagName("emp-no")
。替代方案:在XSD中为这些元素指定相应的空白设置。