新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> XML网站展示,XML源代码,XML编程示例。 本版仅接受原创、转贴、网站展示,具体的技术交流请前往各相关版块。
    [返回] 中文XML论坛 - 专业的XML技术讨论区XML.ORG.CN讨论区 - XML技术『 XML源码及示例(仅原创和转载) 』 → jdom samples (3) 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 2688 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: jdom samples (3) 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     jlive 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:6
      积分:85
      注册:2004/2/17

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给jlive发送一个短消息 把jlive加入好友 查看jlive的个人资料 搜索jlive在『 XML源码及示例(仅原创和转载) 』的所有贴子 引用回复这个贴子 回复这个贴子 查看jlive的博客楼主
    发贴心情 jdom samples (3)

    数据库的配置文件,也由xml形式来设制,且能根够条件,动态配置哦
    <?xml version="1.0" encoding="gb2312"?>
    <!-- ============================================================= -->
    <!-- databases connection config xml file  -->
    <!-- date: 2004-01-13 17:22-->
    <database-config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="database-config.xsd">
     <database-type name="Domino" validate="false">
      <driverClassName>lotus.jdbc.domino.DominoDriver</driverClassName>
      <url>jdbc:domino:DB/Server</url>
      <userName>username</userName>
      <password>password</password>
     </database-type>
     <database-type name="Oracle" validate="true">
      <driverClassName>oracle.jdbc.driver.OracleDriver</driverClassName>
      <url>jdbc:oracle:thin:@host:1521:db</url>
      <userName>username</userName>
      <password>password</password>
     </database-type>
     <database-type name="MS SQLSERVER" validate="false">
      <driverClassName>com.microsoft.jdbc.sqlserver.SQLServerDriver</driverClassName>
      <url>jdbc:microsoft:sqlserver://host:1433;DatabaseName=db</url>
      <userName>username</userName>
      <password>password</password>
     </database-type>
     <database-type name="MySQL" validate="false">
      <driverClassName>org.gjt.mm.mysql.Driver</driverClassName>
      <url>jdbc:mysql://host</url>
      <userName>username</userName>
      <password>password</password>
     </database-type>
    </database-config>

    schema:
    <?xml version="1.0" encoding="UTF-8"?>
    <!-- edited with XMLSPY v5 rel. 4 U (http://www.xmlspy.com) by klfdaskl (fasdfdas) -->
    <!--W3C Schema generated by XMLSPY v5 rel. 4 U (http://www.xmlspy.com)-->
    <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" elementFormDefault="qualified">
     <xs:element name="database-config">
      <xs:complexType>
       <xs:sequence>
        <xs:element ref="database-type" maxOccurs="unbounded"/>
       </xs:sequence>
      </xs:complexType>
     </xs:element>
     <xs:element name="database-type">
      <xs:complexType>
       <xs:sequence>
        <xs:element ref="driverClassName"/>
        <xs:element ref="url"/>
        <xs:element ref="userName"/>
        <xs:element ref="password"/>
       </xs:sequence>
       <xs:attribute name="name" type="xs:string" use="required"/>
       <xs:attribute name="validate" use="required">
        <xs:simpleType>
         <xs:restriction base="xs:NMTOKEN">
          <xs:enumeration value="false"/>
          <xs:enumeration value="true"/>
         </xs:restriction>
        </xs:simpleType>
       </xs:attribute>
      </xs:complexType>
     </xs:element>
     <xs:element name="driverClassName">
      <xs:simpleType>
       <xs:restriction base="xs:string">
        <xs:enumeration value="com.microsoft.jdbc.sqlserver.SQLServerDriver"/>
        <xs:enumeration value="lotus.jdbc.domino.DominoDriver"/>
        <xs:enumeration value="oracle.jdbc.driver.OracleDriver"/>
        <xs:enumeration value="org.gjt.mm.mysql.Driver"/>
       </xs:restriction>
      </xs:simpleType>
     </xs:element>
     <xs:element name="password" type="xs:int"/>
     <xs:element name="url">
      <xs:simpleType>
       <xs:restriction base="xs:string">
        <xs:enumeration value="jdbc:domino:DB/Server"/>
        <xs:enumeration value="jdbc:microsoft:sqlserver://host:1433;DatabaseName=db"/>
        <xs:enumeration value="jdbc:mysql://javasoft"/>
        <xs:enumeration value="jdbc:oracle:thin:@host:1521:db"/>
       </xs:restriction>
      </xs:simpleType>
     </xs:element>
     <xs:element name="userName" type="xs:string"/>
    </xs:schema>


    java原代码:


    package com.sz.xml;

    import com.sz.xml.log.Log;
    import java.util.ArrayList;
    import java.util.List;
    import java.util.Iterator;

    import org.jdom.*;
    import org.jaxen.XPath;
    import org.jaxen.XPathSyntaxException;
    import org.jaxen.JaxenException;
    import org.jaxen.jdom.JDOMXPath;

    public class DatabaseXmlConfig {
      private String driverClassName;
      private String url;
      private String userName;
      private String password;
      private String fileName = "database-config.xml";
      private final String nodeTag = "database-type";
      private Document document;
      private XPath xpath;
      private String sxpath = "/database-config/database-type[@validate='true']";

      public DatabaseXmlConfig() {
        getXmlData(fileName);
      }

      public DatabaseXmlConfig(String fileName) {
        if (fileName != null)
          this.fileName = fileName;
        getXmlData(fileName);
      }

      private void getXmlData(String fileName) {
        List list =null;
        document = GenerateXmlDom.GenerateDomFromXml(fileName, false);
        try{
          xpath = new JDOMXPath(sxpath);
          Element element = (Element) xpath.selectSingleNode(document);
          if(element == null){
            Log.log("DatabaseXmlConfig.getXmlData(String fileName)  ","Err:can't find element; is null");
            return ;
          }else{
            driverClassName = element.getChild("driverClassName").getTextTrim();
            url = element.getChild("url").getTextTrim();
            userName = element.getChild("userName").getTextTrim();
            password = element.getChild("password").getTextTrim();
          }
        /*
          list = xpath.selectNodes(document);
          for(Iterator iter = list.iterator();iter.hasNext();){

          }
          */
        }catch(JaxenException je){
          Log.log("DatabaseXmlConfig.getXmlData :",je.getMessage());
          je.printStackTrace();
        }
      }


      public String getDriverClassName() {
        return this.driverClassName;
      }

      public String getUrl() {
        return this.url;
      }

      public String getUserName() {
        return this.userName;
      }

      public String getPassword() {
        return this.password;
      }

      public static void main(String args[]){
        DatabaseXmlConfig dg = new DatabaseXmlConfig();
        System.out.println(dg.getDriverClassName());
            System.out.println(dg.getUrl());
                System.out.println(dg.getUserName());
                    System.out.println(dg.getPassword());
      }
    }    


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/4/7 15:07:00
     
     struggle 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:9
      积分:93
      门派:XML.ORG.CN
      注册:2004/5/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给struggle发送一个短消息 把struggle加入好友 查看struggle的个人资料 搜索struggle在『 XML源码及示例(仅原创和转载) 』的所有贴子 引用回复这个贴子 回复这个贴子 查看struggle的博客2
    发贴心情 
    谢谢楼主!!!
    楼主能否加进去一些注释啊?真的越来越看不太董了!
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/6/15 8:51:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 XML源码及示例(仅原创和转载) 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/11/13 7:09:42

    本主题贴数2,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    6,345.703ms