java 值Document解析xml详细介绍

时间:2021-05-19

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>的形式

首先从缓存中获取改改结点的值, 如果没有,在从配置文件中读取,

/** * 获取结点的值 * &lt;i&gt;8&lt;/i&gt; * @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; }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章