Java_数据交换_dom4j_01_解析xml

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 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

 

目录
相关文章
|
16天前
|
XML JSON Java
Java中Log级别和解析
日志级别定义了日志信息的重要程度,从低到高依次为:TRACE(详细调试)、DEBUG(开发调试)、INFO(一般信息)、WARN(潜在问题)、ERROR(错误信息)和FATAL(严重错误)。开发人员可根据需要设置不同的日志级别,以控制日志输出量,避免影响性能或干扰问题排查。日志框架如Log4j 2由Logger、Appender和Layout组成,通过配置文件指定日志级别、输出目标和格式。
|
1月前
|
存储 Java 计算机视觉
Java二维数组的使用技巧与实例解析
本文详细介绍了Java中二维数组的使用方法
52 15
|
6天前
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
15 0
|
2月前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
286 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
1月前
|
算法 搜索推荐 Java
【潜意识Java】深度解析黑马项目《苍穹外卖》与蓝桥杯算法的结合问题
本文探讨了如何将算法学习与实际项目相结合,以提升编程竞赛中的解题能力。通过《苍穹外卖》项目,介绍了订单配送路径规划(基于动态规划解决旅行商问题)和商品推荐系统(基于贪心算法)。这些实例不仅展示了算法在实际业务中的应用,还帮助读者更好地准备蓝桥杯等编程竞赛。结合具体代码实现和解析,文章详细说明了如何运用算法优化项目功能,提高解决问题的能力。
73 6
|
1月前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
332 11
|
1月前
|
存储 算法 搜索推荐
【潜意识Java】期末考试可能考的高质量大题及答案解析
Java 期末考试大题整理:设计一个学生信息管理系统,涵盖面向对象编程、集合类、文件操作、异常处理和多线程等知识点。系统功能包括添加、查询、删除、显示所有学生信息、按成绩排序及文件存储。通过本题,考生可以巩固 Java 基础知识并掌握综合应用技能。代码解析详细,适合复习备考。
25 4
|
1月前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
61 7
|
1月前
|
存储 Java
【潜意识Java】期末考试可能考的选择题(附带答案解析)
本文整理了 Java 期末考试中常见的选择题,涵盖数据类型、控制结构、面向对象编程、集合框架、异常处理、方法、流程控制和字符串等知识点。每道题目附有详细解析,帮助考生巩固基础,加深理解。通过这些练习,考生可以更好地准备考试,掌握 Java 的核心概念和语法。
37 1
|
1月前
|
Java 编译器 程序员
【潜意识Java】期末考试可能考的简答题及答案解析
为了帮助同学们更好地准备 Java 期末考试,本文列举了一些常见的简答题,并附上详细的答案解析。内容包括类与对象的区别、多态的实现、异常处理、接口与抽象类的区别以及垃圾回收机制。通过这些题目,同学们可以深入理解 Java 的核心概念,从而在考试中更加得心应手。每道题都配有代码示例和详细解释,帮助大家巩固知识点。希望这些内容能助力大家顺利通过考试!
23 0

推荐镜像

更多