?? mysqldatasourcefactory.java
字號:
/* Copyright (C) 2002-2004 MySQL AB This program is free software; you can redistribute it and/or modify it under the terms of version 2 of the GNU General Public License as published by the Free Software Foundation. There are special exceptions to the terms and conditions of the GPL as it is applied to this software. View the full text of the exception exception in file EXCEPTIONS-CONNECTOR-J in the directory of this software distribution. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */package com.mysql.jdbc.jdbc2.optional;import java.util.Hashtable;import javax.naming.Context;import javax.naming.Name;import javax.naming.Reference;import javax.naming.spi.ObjectFactory;/** * Factory class for MysqlDataSource objects * * @author Mark Matthews */public class MysqlDataSourceFactory implements ObjectFactory { //~ Instance/static variables ............................................. /** * The class name for a standard MySQL DataSource. */ protected final String dataSourceClassName = "com.mysql.jdbc.jdbc2.optional.MysqlDataSource"; /** * The class name for a poolable MySQL DataSource. */ protected final String poolDataSourceName = "com.mysql.jdbc.jdbc2.optional.MysqlConnectionPoolDataSource"; //~ Methods ............................................................... /** * DOCUMENT ME! * * @param refObj DOCUMENT ME! * @param nm DOCUMENT ME! * @param ctx DOCUMENT ME! * @param env DOCUMENT ME! * @return DOCUMENT ME! * @throws Exception DOCUMENT ME! */ public Object getObjectInstance(Object refObj, Name nm, Context ctx, Hashtable env) throws Exception { Reference ref = (Reference) refObj; String className = ref.getClassName(); if (className != null && (className.equals(dataSourceClassName) || className.equals( poolDataSourceName))) { MysqlDataSource dataSource = null; try { dataSource = (MysqlDataSource) Class.forName(className).newInstance(); } catch (Exception ex) { throw new RuntimeException("Unable to create DataSource of " + "class '" + className + "', reason: " + ex.toString()); } int portNumber = 3306; String portNumberAsString = (String) ref.get("port").getContent(); if (portNumberAsString != null) { portNumber = Integer.parseInt(portNumberAsString); } dataSource.setPort(portNumber); String user = (String) ref.get("user").getContent(); if (user != null) { dataSource.setUser(user); } String password = (String) ref.get("password").getContent(); if (password != null) { dataSource.setPassword(password); } String serverName = (String) ref.get("serverName").getContent(); if (serverName != null) { dataSource.setServerName(serverName); } String databaseName = (String) ref.get("databaseName").getContent(); if (databaseName != null) { dataSource.setDatabaseName(databaseName); } String explicitUrlAsString = (String) ref.get("explicitUrl").getContent(); if ("true".equalsIgnoreCase(explicitUrlAsString)) { String url = (String) ref.get("url").getContent(); if (url != null) { dataSource.setUrl(url); } } return dataSource; } else { // We can't create an instance of the reference return null; } }}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -