Skip to content

Commit e5df0df

Browse files
giveme0101giveme01
andauthored
🐛 #1777 XMLXmlUtils修复无法解析<ExtAttr><Item>....</Item></ExtAttr>这种节点数据,如: (#1777)
String xml = "<xml><ToUserName><![CDATA[ww3fb6dc50e568348a]]></ToUserName><FromUserName><![CDATA[sys]]></FromUserName><CreateTime>1600855248</CreateTime><MsgType><![CDATA[event]]></MsgType><Event><![CDATA[change_contact]]></Event><ChangeType><![CDATA[update_user]]></ChangeType><UserID><![CDATA[1000100010001]]></UserID><Gender>2</Gender><ExtAttr><Item><Name><![CDATA[工号]]></Name><Value><![CDATA[10007000000]]></Value><Type>0</Type><Text><Value><![CDATA[10007000000]]></Value></Text></Item></ExtAttr><Alias><![CDATA[xiaoqi]]></Alias></xml>"; 解析后: ExtAttr== null 修复后:ExtAttr={Item=[{Type=0, Value=10007000000, Text={Value=[10007000000]}, Name=工号}]} Co-authored-by: xiajun <xiajun@romens.cn>
1 parent 807ed7d commit e5df0df

File tree

1 file changed

+8
-8
lines changed
  • weixin-java-common/src/main/java/me/chanjar/weixin/common/util

1 file changed

+8
-8
lines changed

weixin-java-common/src/main/java/me/chanjar/weixin/common/util/XmlUtils.java

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -3,10 +3,7 @@
33
import com.google.common.collect.Lists;
44
import com.google.common.collect.Maps;
55
import com.google.common.collect.Sets;
6-
import org.dom4j.Document;
7-
import org.dom4j.DocumentException;
8-
import org.dom4j.Element;
9-
import org.dom4j.Node;
6+
import org.dom4j.*;
107
import org.dom4j.io.SAXReader;
118
import org.dom4j.tree.DefaultText;
129
import org.xml.sax.SAXException;
@@ -50,14 +47,16 @@ public static Map<String, Object> xml2Map(String xmlString) {
5047
}
5148

5249
private static Object element2MapOrString(Element element) {
53-
Map<String, Object> result = Maps.newHashMap();
5450

5551
final List<Node> content = element.content();
56-
if (content.size() <= 1) {
52+
final Set<String> names = names(content);
53+
54+
// 判断节点下有无非文本节点(非Text和CDATA),如无,直接取Text文本内容
55+
if (names.size() < 1) {
5756
return element.getText();
5857
}
5958

60-
final Set<String> names = names(content);
59+
Map<String, Object> result = Maps.newHashMap();
6160
if (names.size() == 1) {
6261
// 说明是个列表,各个子对象是相同的name
6362
List<Object> list = Lists.newArrayList();
@@ -90,7 +89,8 @@ private static Object element2MapOrString(Element element) {
9089
private static Set<String> names(List<Node> nodes) {
9190
Set<String> names = Sets.newHashSet();
9291
for (Node node : nodes) {
93-
if (node instanceof DefaultText) {
92+
// 如果节点类型是Text或CDATA跳过
93+
if (node instanceof DefaultText || node instanceof CDATA) {
9494
continue;
9595
}
9696
names.add(node.getName());

0 commit comments

Comments
 (0)