Java_数据交换_dom4j_01_解析xml

简介: 1.说明 详细原理以后再研究,先将例子存着   2.代码 2.1 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>
View Code

 

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);//递归  
        }  
    }  


}
View Code

 

目录
相关文章
|
5月前
|
机器学习/深度学习 JSON Java
Java调用Python的5种实用方案:从简单到进阶的全场景解析
在机器学习与大数据融合背景下,Java与Python协同开发成为企业常见需求。本文通过真实案例解析5种主流调用方案,涵盖脚本调用到微服务架构,助力开发者根据业务场景选择最优方案,提升开发效率与系统性能。
1356 0
|
5月前
|
Java
Java的CAS机制深度解析
CAS(Compare-And-Swap)是并发编程中的原子操作,用于实现多线程环境下的无锁数据同步。它通过比较内存值与预期值,决定是否更新值,从而避免锁的使用。CAS广泛应用于Java的原子类和并发包中,如AtomicInteger和ConcurrentHashMap,提升了并发性能。尽管CAS具有高性能、无死锁等优点,但也存在ABA问题、循环开销大及仅支持单变量原子操作等缺点。合理使用CAS,结合实际场景选择同步机制,能有效提升程序性能。
|
5月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
516 100
|
6月前
|
存储 缓存 Java
Java数组全解析:一维、多维与内存模型
本文深入解析Java数组的内存布局与操作技巧,涵盖一维及多维数组的声明、初始化、内存模型,以及数组常见陷阱和性能优化。通过图文结合的方式帮助开发者彻底理解数组本质,并提供Arrays工具类的实用方法与面试高频问题解析,助你掌握数组核心知识,避免常见错误。
|
4月前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
5月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
4月前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
4月前
|
XML 数据采集 API
用Lxml高效解析XML格式数据:以天气API为例
免费Python教程:实战解析中国天气网XML数据,详解Lxml库高效解析技巧、XPath用法、流式处理大文件及IP封禁应对策略,助你构建稳定数据采集系统。
282 0
|
5月前
|
安全 Java API
Java SE 与 Java EE 区别解析及应用场景对比
在Java编程世界中,Java SE(Java Standard Edition)和Java EE(Java Enterprise Edition)是两个重要的平台版本,它们各自有着独特的定位和应用场景。理解它们之间的差异,对于开发者选择合适的技术栈进行项目开发至关重要。
844 1
|
6月前
|
存储 缓存 算法
Java数据类型与运算符深度解析
本文深入解析Java中容易混淆的基础知识,包括八大基本数据类型(如int、Integer)、自动装箱与拆箱机制,以及运算符(如&与&&)的使用区别。通过代码示例剖析内存布局、取值范围及常见陷阱,帮助开发者写出更高效、健壮的代码,并附有面试高频问题解析,夯实基础。