java 值Document解析xml详细介绍
更新时间:2017年05月05日 10:11:08 投稿:lqh
这篇文章主要介绍了java 值Document解析xml详细介绍的相关资料,需要的朋友可以参考下
java 值Document解析xml详细介绍
使用jar包:jdom.jar
配置文件格式 global.xml

一、获取输入的值组成的结点
我们将每个结点使用“.” 拼接起来, 如结点i ,拼接为abc.def.i, 注意不包含root。解析每个结点的名字。
/**
* 获取对应结点的名字
* @param name 不包含root结点的拼接,ie: abc.def.i
* @return
*/
private String[] parsePropertyName(String name) {
//结点序号从0开始
int size = name.split("\\.").length;
String[] parms =name.split("\\.");
return parms;
}
二、获取对应结点的值
2.1、结点为<name valueName=”value123”>的形式
/**
* abc.def.i结点下有个结点为:
* <name valueName="value123">
* 获取对应结点的value<br>
* @param name 结点的值(name,是不包含root结点, 使用"."拼接的, ie: abc.def.i)
* @param defaultName 没有获取到该节点内容, 返回默认值
* @return
*/
public synchronized String getPropertyValue(String name, String valueName) {
//获取根结点对象
Element element = doc.getRootElement();
//获取各级结点对应的属性
String[] parms = parsePropertyName(name);
for (String parm : parms) {
element = element.getChild(parm);
}
//得到无儿子结点的element的属性值
return element.getAttributeValue(valueName);
}
2.2. 结点为 <i>8</i>的形式
首先从缓存中获取改改结点的值, 如果没有,在从配置文件中读取,
/**
* 获取结点的值
* <i>8</i>
* @param name 叶子结点的值(name,是不包含root结点, 使用"."拼接的, ie: abc.def.i)
* @return
*/
public synchronized String getProperty(String name) {
//先从缓存中获取
String value = cacheMap.get(name);
if (value != null) {
return value;
}
Element element = getElementByName(name);
if (element == null) {
return null;
}
//获取value
value = element.getText();
//缓存
cacheMap.put(name, value);
return value;
}
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
相关文章
详解为什么阿里巴巴禁止使用BigDecimal的equals方法做等值比较
这篇文章主要介绍了详解为什么阿里巴巴禁止使用BigDecimal的equals方法做等值比较,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-09-09
IntelliJ IDEA JRebel 安装使用图文教程(热部署插件)
IDEA 全称 IntelliJ IDEA,是java语言开发的集成环境,IntelliJ在业界被公认为最好的java开发工具之一。这篇文章主要介绍了IntelliJ IDEA 热部署插件JRebel 安装使用图文教程,需要的朋友可以参考下2018-03-03


最新评论