Jakarta commons-configuration

概要

  1. http://jakarta.apache.org/commons/configuration/
    • どんな設定ファイルでもどんと来いライブラリ
  2. 対応している設定ファイルの書式
    • Properties files
    • XML documents
    • Property list files (.plist)
    • JNDI
    • JDBC Datasource
    • System properties
    • Applet parameters
    • Servlet parameters
  3. ここでは、XML documents の読み込みを試してみる
  4. commons-configuration が使用している依存ライブラリがわんさかあるので、Maven2 ベースの開発でないと大変。
  5. Maven2 の場合には、pom.xml に依存ライブラリとして commons-configuration を指定するだけ
    <dependencies>
       <dependency>
         <groupId>commons-configuration</groupId>
         <artifactId>commons-configuration</artifactId>
         <version>1.3</version>
         <scope>runtime</scope>
       </dependency>
       ・・・

練習問題

  1. 読み込むXML設定ファイル配下のような物 (拙作IPMsgletの設定ファイル)
  2. <user-name> などは、一意な項目
  3. <msglet> などは、繰り返し項目
    Everything is expanded. Everything is shortened.
      1
      2
      3
      4
      5
      6
      7
      8
      9
     10
     11
     12
     13
     14
     15
     16
     17
     18
     19
     20
     21
     22
     23
     24
     25
     26
     27
     28
     29
     30
     31
     32
     33
     34
     35
     36
     37
     38
     39
     40
     41
     42
    
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
    
    <?xml version="1.0" encoding="UTF-8"?>
    <msg-app>
     
      <!-- application scope variables -->
      <context-param>
        <user-name>root</user-name>
        <nick-name>root</nick-name>
        <group>Msglet</group>
        <debug>true</debug>
      </context-param>
      
      <!-- msglet settings -->
      <msglet>
        <msglet-name>Sanmoku</msglet-name>
        <msglet-class>com.snail.msglet.sample.SampleMsglet</msglet-class>
        <init-param>
          <param-name>width</param-name>
          <param-value>3</param-value>
        </init-param>
        <init-param>
          <param-name>height</param-name>
          <param-value>3</param-value>
        </init-param>
      </msglet>
      
      <msglet>
        <msglet-name>Gomoku</msglet-name>
        <msglet-class>com.snail.msglet.sample.SampleMsglet</msglet-class>
        <init-param>
          <param-name>width</param-name>
          <param-value>5</param-value>
        </init-param>
        <init-param>
          <param-name>height</param-name>
          <param-value>5</param-value>
        </init-param>
      </msglet>
      
      <!-- startup msglet -->
      <welcome-msglet>Sanmoku</welcome-msglet>
     
    </msg-app>

一意な項目の取得

  1. XML設定ファイルを読み込んで
    • XMLConfiguration config = new XMLConfiguration("msg.xml");
  2. config から getXXX() で、項目を読み取るだけ
    • String welcome = config.getString(WELCOME_MSGLET);
    • xml の path には、root(ここでは <msg-app> )を含まない
  3. このとき、第二引数を指定するとデフォルト値(設定ファイルに設定がない場合の値)を設定できる
    • boolean debug = config.getBoolean(DEBUG, false);
      Everything is expanded. Everything is shortened.
        1
        2
        3
        4
        5
        6
        7
        8
        9
       10
       11
       12
       13
       14
       15
       16
       17
       18
       19
       20
       21
       22
       23
       24
       25
       26
       27
       28
       29
       30
       31
       32
       33
       34
       35
       36
       37
       38
       39
       40
       41
       42
       43
       44
       45
       46
       47
       48
       49
       50
       51
       52
       53
       54
       55
       56
       57
       58
       59
       60
       61
       62
       63
       64
       65
       66
      
      -
      |
      |
      |
      |
      |
      |
      -
      |
      |
      -
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      -
      |
      |
      -
      -
      -
      |
      -
      |
      !
      !
      !
      !
      |
      |
      |
      |
      -
      |
      |
      |
      -
      |
      |
      -
      -
      |
      !
      !
      -
      |
      !
      !
      !
      
      public final class Startup {
        private static final String USER_NAME = "context-param.user-name";
        private static final String NICK_NAME = "context-param.nick-name";
        private static final String GROUP = "context-param.group";
        private static final String DEBUG = "context-param.debug";
        private static final String WELCOME_MSGLET = "welcome-msglet";
        
        public static void main(final String[] args) {
          MsgletContainer container = null;
       
          try {
            XMLConfiguration config = new XMLConfiguration("msg.xml");
       
            String userName = config.getString(USER_NAME, "Msglet");
            String nickName = config.getString(NICK_NAME, "Msglet");
            String group = config.getString(GROUP, "Msglet");
            boolean debug = config.getBoolean(DEBUG, false);
            String welcome = config.getString(WELCOME_MSGLET);
       
            container = new MsgletContainer(
                userName,
                nickName,
                group,
                debug,
                welcome);
       
            container.setMsgletMap(MsgletFactory.createMsglets(config));
       
            container.login();
            container.start();
       
            waitTerminate();
          } catch (Exception ex) {
            ex.printStackTrace();
            System.exit(-1);
          } finally {
            if (container != null) {
              try { container.logout(); } catch (IOException e) { e.printStackTrace(); }
            }
          }
        }
       
        /**
         * 空文字か、"shutodwn"が入力されるまで入力待ちをします .
         */
        private static void waitTerminate() {
          BufferedReader breader =
            new BufferedReader(new InputStreamReader(System.in));
       
          try {
            String line = null;
       
            while ((line = breader.readLine()) != null) {
              if ("shutdown".equals(line)) { break; }
            }
          } catch (IOException ignoreEx) {
            ignoreEx.printStackTrace();
          }
        }
      }

繰り返し項目の取得

  1. commons-configuration は、xml の 末端しか取得することができない
  2. 次のような msglet 定義がなされているときに、msglet-nameは二通りのやり方で取得できる
    ・・・
    <msglet>
      <msglet-name>a-msglet</msglet-name>
      <msglet-class>com.snail.AMsglet</msglet-class>
    </msglet>
    <msglet>
      <msglet-name>b-msglet</msglet-name>
      <msglet-class>com.snail.BMsglet</msglet-class>
    </msglet>
    ・・・
    1. String name = config.getString( "msglet(n).msglet-name" );
    2. Collection names = (Collection)config.getObject( "msglet.msglet-name" );
  3. そこで、繰り返し項目を扱うときには次の手順を踏む
    1. 繰り替えしブロックの中で、必ず登場する項目( ex."msglet.msglet-name" )の登場回数を調べる (getRepetition())。
    2. この登場回数が、繰り返しブロックの個数と同じ
    3. 繰り返しブロック数が1ならば、一意項目として読み込む
      name[0]  = config.getString("msglet.msglet-name");
      class[0] = config.getString("msglet.msglet-class");
    4. 繰り返しブロック数が1より大きければ、繰り替えし数を指定して読みこむ
      for(int n = 0 ; n < repetition ; n++){
        name[n]  = config.getString("msglet(n).msglet-name");
        class[n] = config.getString("msglet(n).msglet-class");
      }
    5. Code Template
      Everything is expanded. Everything is shortened.
        1
        2
        3
        4
        5
        6
        7
        8
        9
       10
       11
       12
       13
       14
       15
       16
       17
       18
       19
       20
       21
       22
       23
       24
       25
       26
       27
       28
       29
       30
       31
       32
       33
       34
       35
       36
       37
       38
       39
       40
       41
       42
       43
       44
       45
       46
       47
       48
       49
       50
       51
       52
       53
       54
       55
       56
       57
       58
      
      -
      |
      |
      |
      |
      |
      |
      |
      |
      |
      |
      -
      |
      |
      |
      |
      |
      |
      -
      |
      |
      |
      |
      |
      |
      |
      |
      -
      -
      |
      |
      |
      |
      |
      |
      |
      |
      |
      !
      !
      |
      |
      !
      |
      |
      |
      -
      |
      |
      -
      |
      -
      |
      !
      |
      |
      !
      !
      
      public final class MsgletFactory {
        private static final String MSGLET = "msglet";
        private static final String MSGLET_NAME = "msglet-name";
        private static final String MSGLET_CLASS = "msglet-class";
        private static final String INIT_PARAM = "init-param";
        private static final String PARAM_NAME = "param-name";
        private static final String PARAM_VALUE = "param-value";
        
        public static Map<String, Msglet> createMsglets(
          final XMLConfiguration config)
          throws InstantiationException, IllegalAccessException,
            ClassNotFoundException, ConfigurationException {
          Map<String, Msglet> retMap = new HashMap<String, Msglet>();
       
          // necessary tag
          String pibot = MSGLET + "." + MSGLET_NAME;
          int repetition = getRepetition(config, pibot);
       
          if (repetition == 1) {
            String name = config.getString(MSGLET + "." + MSGLET_NAME);
            Msglet msglet =
              createMsglet(config.getString(MSGLET + "." + MSGLET_CLASS));
       
            msglet.setInitParamMap(
              createInitParams(MSGLET + "." + INIT_PARAM, config));
       
            retMap.put(name, msglet);
          } else if (repetition > 1) {
            for (int cnt = 0; cnt < repetition; cnt++) {
              String name = config.getString(MSGLET + "(" + cnt + ")." + MSGLET_NAME);
              Msglet msglet =
                createMsglet(
                    config.getString(MSGLET + "(" + cnt + ")." + MSGLET_CLASS));
       
              msglet.setInitParamMap(
                  createInitParams(MSGLET + "(" + cnt + ")." + INIT_PARAM, config));
       
              retMap.put(name, msglet);
            }
          }
       
          return retMap;
        }
        ・・・
        private static int getRepetition(
          final XMLConfiguration config,
          final String path) {
          Object obj = config.getProperty(path);
       
          if (obj == null) {
            return 0;
          } else if (obj instanceof Collection) {
            return ((Collection) obj).size();
          }
       
          return 1;
        }
      

资源简介 Jakarta commons docs API CHM 格式带索引和全文搜索,方便携带和查询。 Jakarta commons 包含很多可复用的通用组件。 commons-attributes 让开发者可以使用 C# 或 .net 样式的 attributes, 是一种运行时的 api, 有点类似 doclet commons-beanutils 提供对 Java 反射和自省API的包装 commons-betwixt 这个组件提供一个XML自省(introspection)机制用来把Java Bean映射到XML文档 commons-chain 提供实现组织复杂的处理流程的“责任链模式” commons-cli 命令行参数解析 , 由 Werken, Avalon 和 Optz 组成 commons-codec 包含一些通用的编码解码算法。包括一些语音编码器, Hex, Base64, 以及URL encoder. commons-collections 扩充了 java.util.collection 接口 commons-compress 操作压缩文件的 API commons-configuration 可以从xmlproperties、JNDI、JDBC、System properties、Applet parameters和Servlet parameters等读取信息 commons-daemon 可以帮你实现将一个普通的 Java 应用变成系统的一个后台服务 commons-dbcp 数据连接池服务 commons-dbutils JDBC 辅助类 commons-digester XML 文件到 Java 对象的映射机制 commons-discovery 提供工具来定位资源 (包括类) ,通过使用各种模式来映射服务/引用名称和资源名称。 commons-el 提供在JSP2.0规范中定义的EL表达式的解释器. commons-email 提供一组用于发送Email的API,它基于Java Mail API基础之上并进行了简化 commons-exec 处理外部进程的执行或管理外部环境 commons-fileupload 使得在你可以在应用和Servlet中容易的加入强大和高性能的文件上传能力 commons-io 用来帮助进行IO功能开发.它包含三个主要的领域:Utility classes-提供一些静态方法来完成公共任务.Filters-提供文件过滤器的各种实现.Streams-提供实用的Stream,reader与 writer实现 commons-jelly 能够把XML转换成可执行代码,所以Jelly是一个基于XML与Java的脚本和处理引擎 commons-jexl 是一个表达式语言,通过借鉴来自于Velocity的经验扩展了JSTL定义的表达式语言 commons-jxpath 定义了一个简单的XPath表达式语言的解析器.JXPath应用XPath表达式来操纵各种类型的对象包括:JavaBeans,Maps,Servlet contexts,DOM等 commons-lang commons的基础包 commons-launcher 提供多平台的 Java 程序加载 commons-logging 提供日志的实现 commons-math 是一个轻量的,自包含的数学和统计组件,解决了许多非常通用但没有及时出现在Java标准语言中的实践问题. commons-modeler 创建符合 JMX 规范的 MBeans 机制 commons-net 网络和协议实现的集合 commons-pool 提供了通用对象池接口,一个用于创建模块化对象池的工具包,以及通常的对象池实 commons-primitives java 简单类型使用的扩展 commons-proxy 创建动态代理的库 commons-scxml commons-transaction 处理多级事务的集合 commons-validator 提供了一个简单的,可扩展的框架来在一个XML文件中定义校验器 (校验方法)和校验规则 commons-vfs 虚拟文件系统 httpcomponents-client 和 http 协议客户端一起协作的框架 httpcomponents-core jakarta-oro 一套文本处理工具,能提供perl5.0兼容的正则表达式,AWK-like正则表达式, glob表达式。还提供替换,分割,文件名过虑等功能 jakarta-regexp 是一个100%纯java正则式处理包,是Jonathan Locke捐给Apache软件基金会的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值