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

 

目录
相关文章
|
2月前
|
机器学习/深度学习 JSON Java
Java调用Python的5种实用方案:从简单到进阶的全场景解析
在机器学习与大数据融合背景下,Java与Python协同开发成为企业常见需求。本文通过真实案例解析5种主流调用方案,涵盖脚本调用到微服务架构,助力开发者根据业务场景选择最优方案,提升开发效率与系统性能。
486 0
|
2月前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
167 4
|
2月前
|
Java
Java的CAS机制深度解析
CAS(Compare-And-Swap)是并发编程中的原子操作,用于实现多线程环境下的无锁数据同步。它通过比较内存值与预期值,决定是否更新值,从而避免锁的使用。CAS广泛应用于Java的原子类和并发包中,如AtomicInteger和ConcurrentHashMap,提升了并发性能。尽管CAS具有高性能、无死锁等优点,但也存在ABA问题、循环开销大及仅支持单变量原子操作等缺点。合理使用CAS,结合实际场景选择同步机制,能有效提升程序性能。
|
2月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
374 100
|
3月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
18天前
|
存储 安全 Java
《数据之美》:Java集合框架全景解析
Java集合框架是数据管理的核心工具,涵盖List、Set、Map等体系,提供丰富接口与实现类,支持高效的数据操作与算法处理。
|
2月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
16天前
|
存储 人工智能 算法
从零掌握贪心算法Java版:LeetCode 10题实战解析(上)
在算法世界里,有一种思想如同生活中的"见好就收"——每次做出当前看来最优的选择,寄希望于通过局部最优达成全局最优。这种思想就是贪心算法,它以其简洁高效的特点,成为解决最优问题的利器。今天我们就来系统学习贪心算法的核心思想,并通过10道LeetCode经典题目实战演练,带你掌握这种"步步为营"的解题思维。
|
16天前
|
XML 数据采集 API
用Lxml高效解析XML格式数据:以天气API为例
免费Python教程:实战解析中国天气网XML数据,详解Lxml库高效解析技巧、XPath用法、流式处理大文件及IP封禁应对策略,助你构建稳定数据采集系统。
115 0
|
2月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
160 16

推荐镜像

更多
  • DNS