首页 > 编程 > Java > 正文

java 值Document解析xml详细介绍

2019-11-26 12:22:31
字体:
来源:转载
供稿:网友

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;  }

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表