java 值Document解析xml详细介绍

发布时间:2020-09-30 16:22:44 作者:lqh
来源:脚本之家 阅读:200

java 值Document解析xml详细介绍

使用jar包:jdom.jar

配置文件格式 global.xml

java 值Document解析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;
  }

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

推荐阅读:
  1. Java中解析XML的方式是什么
  2. 怎么实现java DOMParser 解析xml

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java document 解析xml

上一篇:租用虚拟主机的好处有什么

下一篇:如何安装ecshop

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》