⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rcdata.java

📁 hsql是很有名的嵌入式数据库
💻 JAVA
字号:
/* Copyright (c) 2001-2005, The HSQL Development Group
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * Redistributions of source code must retain the above copyright notice, this
 * list of conditions and the following disclaimer.
 *
 * Redistributions in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * Neither the name of the HSQL Development Group nor the names of its
 * contributors may be used to endorse or promote products derived from this
 * software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG,
 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */


package org.hsqldb.util;import java.io.BufferedReader;import java.io.File;import java.io.FileReader;import java.io.IOException;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.Properties;import java.util.StringTokenizer;/* $Id: RCData.java,v 1.7 2005/06/08 19:52:37 fredt Exp $ *//** * All the info we need to connect up to a database. * * @author Blaine Simpson unsaved@users */public class RCData {    public static final String DEFAULT_JDBC_DRIVER = "org.hsqldb.jdbcDriver";    /**     * Just for testing and debugging.     */    public void report() {        System.err.println("urlid: " + id + ", url: " + url + ", username: "                           + username + ", password: " + password);    }    /**     * Creates a RCDataObject by looking up the given key in the     * given authentication file.     *     * @param String dbKey Key to look up in the file.     * @param inFile File containing the authentication information.     */    public RCData(File file, String dbKey) throws Exception {        if (file == null) {            throw new IllegalArgumentException("RC file name not specified");        }        if (!file.canRead()) {            throw new IOException("Please set up authentication file '"                                  + file + "'");        }        // System.err.println("Using RC file '" + file + "'");        StringTokenizer tokenizer = null;        boolean         thisone   = false;        String          s;        String          keyword, value;        int             linenum = 0;        BufferedReader  br      = new BufferedReader(new FileReader(file));        while ((s = br.readLine()) != null) {            ++linenum;            s = s.trim();            if (s.length() == 0) {                continue;            }            if (s.charAt(0) == '#') {                continue;            }            tokenizer = new StringTokenizer(s);            if (tokenizer.countTokens() == 1) {                keyword = tokenizer.nextToken();                value   = "";            } else if (tokenizer.countTokens() > 1) {                keyword = tokenizer.nextToken();                value   = tokenizer.nextToken("").trim();            } else {                try {                    br.close();                } catch (IOException e) {}                throw new Exception("Corrupt line " + linenum + " in '"                                    + file + "':  " + s);            }            if (dbKey == null) {                if (keyword.equals("urlid")) {                    System.out.println(value);                }                continue;            }            if (keyword.equals("urlid")) {                if (value.equals(dbKey)) {                    if (id == null) {                        id      = dbKey;                        thisone = true;                    } else {                        try {                            br.close();                        } catch (IOException e) {}                        throw new Exception("Key '" + dbKey + " redefined at"                                            + " line " + linenum + " in '"                                            + file);                    }                } else {                    thisone = false;                }                continue;            }            if (thisone) {                if (keyword.equals("url")) {                    url = value;                } else if (keyword.equals("username")) {                    username = value;                } else if (keyword.equals("driver")) {                    driver = value;                } else if (keyword.equals("charset")) {                    charset = value;                } else if (keyword.equals("truststore")) {                    truststore = value;                } else if (keyword.equals("password")) {                    password = value;                } else {                    try {                        br.close();                    } catch (IOException e) {}                    throw new Exception("Bad line " + linenum + " in '"                                        + file + "':  " + s);                }            }        }        try {            br.close();        } catch (IOException e) {}        if (dbKey == null) {            return;        }        if (url == null || username == null || password == null) {            throw new Exception("url or username or password not set "                                + "for '" + dbKey + "' in file '" + file                                + "'");        }    }    String id         = null;    String url        = null;    String username   = null;    String password   = null;    String driver     = null;    String charset    = null;    String truststore = null;    /**     * Gets a JDBC Connection using the data of this RCData object.     *     * @return New JDBC Connection     */    public Connection getConnection()    throws ClassNotFoundException, InstantiationException,           IllegalAccessException, SQLException {        return getConnection(null, null, null);    }    /**     * Gets a JDBC Connection using the data of this RCData object with     * specified override elements     *     * @return New JDBC Connection     */    public Connection getConnection(String curDriver, String curCharset,                                    String curTrustStore)                                    throws ClassNotFoundException,                                           InstantiationException,                                           IllegalAccessException,                                           SQLException {        Properties sysProps = System.getProperties();        if (curDriver == null) {            // If explicit driver not specified            curDriver = ((driver == null) ? DEFAULT_JDBC_DRIVER                                          : driver);        }        if (curCharset == null && charset != null) {            curCharset = charset;        }        if (curTrustStore == null && truststore != null) {            curTrustStore = truststore;        }        if (curCharset == null) {            sysProps.remove("sqlfile.charset");        } else {            sysProps.put("sqlfile.charset", curCharset);        }        if (curTrustStore == null) {            sysProps.remove("javax.net.ssl.trustStore");        } else {            sysProps.put("javax.net.ssl.trustStore", curTrustStore);        }        // As described in the JDBC FAQ:        // http://java.sun.com/products/jdbc/jdbc-frequent.html;        // Why doesn't calling class.forName() load my JDBC driver?        // There is a bug in the JDK 1.1.x that can cause Class.forName()        // to fail. // new org.hsqldb.jdbcDriver();        Class.forName(curDriver).newInstance();        return DriverManager.getConnection(url, username, password);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -