专栏首页Java成神之路Java_数据交换_dom4j_01_解析xml

Java_数据交换_dom4j_01_解析xml

1.说明

详细原理以后再研究,先将例子存着

2.代码

2.1 xml内容

<?xml version="1.0" encoding="UTF-8"?>
<weixin:Qi-config xmlns:weixin="aurora.plugin.weixin">
    <instnces>    
            <weixin:Qiyeance token="wei胜多负少xin" corpId=防守打法b5a4889c1e12" encodingAESKey="z3s7Tgh3mknc2电饭锅w5MevwYocgmEL1Gtw" appName="规定发给c"/>
    </instnces>
    <tokenTasks>
    <weixin:Qiyask groupname="hec" corpId="wwa4889c1e12" secrect="kOpZjWDSmdhghOB7fydfFW6m0-sSMOQYV_Cko" />
    </tokenTasks>
</weixin:Qi-config>

2.2java 代码

package com.ray.test;

import java.io.File;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.junit.Test;

public class TestParseXMl {
    Map<String, Map<String,String>> weiXinConfigMap=new HashMap<String, Map<String,String>>();
    /**
     * 获取文件的document对象,然后获取对应的根节点   
     * @throws Exception
     */
    @Test  
    public void testGetRoot() throws Exception{  
        SAXReader sax=new SAXReader();//创建一个SAXReader对象  
        //File xmlFile=new File("src/main/java/aurora/plugin/weixin/qiyewexin.config");//根据指定的路径创建file对象  
        File xmlFile=new File("src/com/ray/test/qiyewexin.config");//根据指定的路径创建file对象  
        Document document=sax.read(xmlFile);//获取document对象,如果文档无节点,则会抛出Exception提前结束  
        Element root=document.getRootElement();//获取根节点  
        this.getNodes(root);//从根节点开始遍历所有节点  
        
        for(String key:weiXinConfigMap.keySet()){
            System.out.println("节点名字:key"+key);
            Map<String ,String> attMap=weiXinConfigMap.get(key);
            for(String key2:attMap.keySet()){
                System.out.println("属性名:"+key2+ ",属性值:"+attMap.get(key2));
            }
        }

    }  

    /**
     * 从指定节点开始,递归遍历所有子节点   
     * @param node
     */
    public void getNodes(Element node ){  
        System.out.println("--------------------");  

        //当前节点的名称、文本内容和属性  
        System.out.println("当前节点名称:"+node.getName());//当前节点名称  
        System.out.println("当前节点的内容:"+node.getTextTrim());//当前节点名称  
        List<Attribute> listAttr=node.attributes();//当前节点的所有属性的list  
        Map<String,String> attrMap=new HashMap<String,String>();

        for(Attribute attr:listAttr){//遍历当前节点的所有属性  
            String name=attr.getName();//属性名称  
            String value=attr.getValue();//属性的值  
            System.out.println("属性名称:"+name+"属性值:"+value);  
            //将微信配置属性存入map
            if("QiyeWeixin-instance".equals(node.getName())||"QiyeToken-task".equals(node.getName())){
                attrMap.put(name, value);
            }
        }  

        //递归遍历当前节点所有的子节点  
        List<Element> listElement=node.elements();//所有一级子节点的list  
        for(Element e:listElement){//遍历所有一级子节点  
            this.getNodes(e);//递归  
        }  

        if("QiyeWeixin-instance".equals(node.getName())||"QiyeToken-task".equals(node.getName())){
            weiXinConfigMap.put(node.getName(), attrMap);
        }
    }  



    /**
     * 从指定节点开始,递归遍历所有子节点   
     * @param node
     */
    public void getNodes0(Element node){  
        System.out.println("--------------------");  

        //当前节点的名称、文本内容和属性  
        System.out.println("当前节点名称:"+node.getName());//当前节点名称  
        System.out.println("当前节点的内容:"+node.getTextTrim());//当前节点名称  
        List<Attribute> listAttr=node.attributes();//当前节点的所有属性的list  
        for(Attribute attr:listAttr){//遍历当前节点的所有属性  
            String name=attr.getName();//属性名称  
            String value=attr.getValue();//属性的值  
            System.out.println("属性名称:"+name+"属性值:"+value);  
        }  

        //递归遍历当前节点所有的子节点  
        List<Element> listElement=node.elements();//所有一级子节点的list  
        for(Element e:listElement){//遍历所有一级子节点  
            this.getNodes(e);//递归  
        }  
    }  


}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • hive_学习_02_hive整合hbase(失败)

    本文承接上一篇:hive_学习_01_hive环境搭建(单机) ,主要是记录 hive 整合hbase的流程

    shirayner
  • Java企业微信开发_08_素材管理之下载微信临时素材到本地服务器

    请求地址:https://qyapi.weixin.qq.com/cgi-bin/media/get?access_token=ACCESS_TOKEN&med...

    shirayner
  • Java微信公众平台开发_06_素材管理

    shirayner
  • 自平衡二叉树实现及时间复杂度分析

    我们在遍历二叉树时,先一直往左遍历,于是我们发现,当一棵树的每个节点都只有一个子节点时,他就变成了一个链表,然后链表就说啊:

    不作声
  • 数据结构与前端开发(四)-树

    二叉树拥有一个根节点,每个节点至多拥有两个子节点,分别为:左节点和右节点。树的最底部节点称之为叶节点,当一颗树的叶数量数量为满时,该树可以称之为满二叉树。

    前端迷
  • 二叉树的实现、遍历及面试题

    如图就是一个树结构,最上边的叫「根节点」,最下边的叫「叶子节点」。根节点有多个子节点,叶子节点没有子节点。二叉树就是,每个节点最多有两个子节点的树。

    不作声
  • Rainbond集群的安装和运维的原理

    本文将解读Rainbond集群的安装和运维的原理,使用户基本了解Rainbond的安装机制和运维重点,便于用户搭建大型Rainbond集群。

    Rainbond开源
  • 【算法】二叉树中找到一个节点的后继节点,前继节点

    该结构比普通二叉树节点结构多了一个指向父节点parent指针。 假设有一 棵Node类型的节点组成的二叉树,树中每个节点的parent指针都正确地指向自己的父...

    MapleYe
  • 树补白:自平衡

    BST问题在于可能存在很深很深的层。因此导致数据遍历的性能问题。为此引入AVL树,整棵树的层级高度之差总是为1.

    一粒小麦
  • Leetcode刷题 237. 删除链表中的节点 两行代码实现

    请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点。传入函数的唯一参数为 要被删除的节点 。 现有一个链表 -- head = [4,5,1,9],它...

    一只胡说八道的猴子

扫码关注云+社区

领取腾讯云代金券