当前位置: 代码网 > it编程>编程语言>Javascript > 使用dom4j实现xml转map与xml转json字符串

使用dom4j实现xml转map与xml转json字符串

2024年11月06日 Javascript 我要评论
dom4j依赖包 <!--dom4j--> <dependency> <groupid>dom4j</gro

 dom4j依赖包

        <!--dom4j-->
        <dependency>
            <groupid>dom4j</groupid>
            <artifactid>dom4j</artifactid>
            <version>1.6.1</version>
        </dependency>

map转为json字符串方法很多,这里使用fastjson

        <!--fastjson 版本1.2.78是fastjson在发布时的最后一个支持java 1.7的版本-->
        <dependency>
            <groupid>com.alibaba</groupid>
            <artifactid>fastjson</artifactid>
            <version>1.2.78</version>
        </dependency>

dom4j实现xml转map,再使用 fastjson 将map转为json字符串

package com.study;
 
import com.alibaba.fastjson.json;
import org.dom4j.document;
import org.dom4j.documentexception;
import org.dom4j.documenthelper;
import org.dom4j.element;
 
import java.util.arraylist;
import java.util.linkedhashmap;
import java.util.list;
import java.util.map;
 
public class test {
    public static void main(string[] args) throws exception {
        string xml = "<sites><site><name>runoob</name><url>www.runoob.com</url></site><site><name>google</name><url>www.google.com</url></site><site><name>facebook</name><url>www.facebook.com</url></site></sites>";
        map<string, object> map = xml2map(xml);
        string json = json.tojsonstring(map);
        system.out.println(json);
    }
 
    /**
     * xml转map 不带属性
     */
    public static map<string, object> xml2map(string xml) throws documentexception {
        // xml必须有一个根节点
        xml = "<root>" + xml + "</root>";
        document document = documenthelper.parsetext(xml);
        element root = document.getrootelement(); //根节点
        map<string, object> map = xml2map(root);
        return map;
    }
 
    /**
     * xml转map 不带属性
     * 如果是兄弟元素,并且兄弟元素的标签相同,那么这些相同名称的兄弟需要合并为一个数组
     */
    private static map<string, object> xml2map(element element) {
        map<string, object> map = new linkedhashmap<>();
        list<element> list = element.elements(); //获取所有子节点
        if (list.size() > 0) { //有子节点
            for (element iter : list) { //遍历所有子节点
                list<object> maplist;
                if (iter.elements().size() > 0) { //子节点还有子节点
                    map<string, object> m = xml2map(iter); //递归调用
                    if (map.get(iter.getname()) != null) { //标签名称已经存在,说明是一个数组结构
                        object obj = map.get(iter.getname());
                        if (obj instanceof list) { //标签的值是数组结构,取出数组添加新的元素
                            maplist = (list) obj; //取出旧值
                            maplist.add(m); //放入新值
                        } else {
                            maplist = new arraylist<>();
                            maplist.add(obj); //放入旧值
                            maplist.add(m); //放入新值
                        }
                        map.put(iter.getname(), maplist);
                    } else {
                        map.put(iter.getname(), m);
                    }
                } else { //子节点无子节点
                    if (map.get(iter.getname()) != null) { //标签名称已经存在,说明是一个数组结构
                        object obj = map.get(iter.getname());
                        if (obj instanceof list) { //标签的值是数组结构,取出数组添加新的元素
                            maplist = (list) obj; //取出旧值
                            maplist.add(iter.gettext()); //放入新值
                        } else {
                            maplist = new arraylist<>();
                            maplist.add(obj); //放入旧值
                            maplist.add(iter.gettext()); //放入新值
                        }
                        map.put(iter.getname(), maplist);
                    } else {
                        map.put(iter.getname(), iter.gettext());
                    }
                }
            }
        }
        return map;
    }
 
}

效果如下:

<sites>
    <site>
        <name>runoob</name>
        <url>www.runoob.com</url>
    </site>
    <site>
        <name>google</name>
        <url>www.google.com</url>
    </site>
    <site>
        <name>facebook</name>
        <url>www.facebook.com</url>
    </site>
</sites>

xml转换为json后效果

{
	"sites": {
		"site": [
			{
				"name": "runoob",
				"url": "www.runoob.com"
			},
			{
				"name": "google",
				"url": "www.google.com"
			},
			{
				"name": "facebook",
				"url": "www.facebook.com"
			}
		]
	}
}

到此这篇关于使用dom4j实现xml转map与xml转json字符串的文章就介绍到这了,更多相关dom4j xml转map与xml转json内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com