`
zhangwenping
  • 浏览: 15510 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
社区版块
存档分类
最新评论

JAVA模拟 工厂方法

阅读更多

定义一个功能性接口

package model;

import java.sql.Connection;
import java.sql.SQLException;

public interface BuildConnection {
	Connection getConnection() throws SQLException;
}

 实现一个具体的connection产品,它实现BuildConnection的接口

package model;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource;

public class DataSourceConnection implements BuildConnection {
	
	private static Properties prop = new Properties();
	
	private DataSource ds;
	
	private String initialContextFactory;
	
	private String providerUrl;
	
	private String securityPrincipal;
	
	private String securityCredentials;
	
	private String dataSource;
	
	public DataSourceConnection(String securityPrincipal, String securityCredentials, String dataSource, String providerUrl, String initialContextFactory) throws NamingException {
		this.securityPrincipal = securityPrincipal;
		this.securityCredentials = securityCredentials;
		this.dataSource = dataSource;
		this.providerUrl = providerUrl; 
		this.initialContextFactory = initialContextFactory;
		loadDriver();
	}

	public Connection getConnection() throws SQLException {
		return ds.getConnection();
	}
	
	private void loadDriver() throws NamingException {
		if (!(prop.contains(initialContextFactory) && prop.contains(providerUrl) && prop.contains(securityPrincipal) && prop.contains(securityCredentials))) {
			prop.put(Context.INITIAL_CONTEXT_FACTORY, initialContextFactory);
			prop.put(Context.PROVIDER_URL, providerUrl);
			prop.put(Context.SECURITY_PRINCIPAL, securityPrincipal);
			prop.put(Context.SECURITY_CREDENTIALS, securityCredentials);
		}
		Context context = new InitialContext(prop);
		ds =(DataSource)context.lookup(dataSource); 
	}

}

 实现另一个具体的connection产品,它实现BuildConnection的接口

package model;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.HashSet;
import java.util.Set;

public class DriverManagerConnection implements BuildConnection {
	
	private static Set<String> set = new HashSet<String>();
	
	private String driver;
	
	private String url;
	
	private String userId;
	
	private String password;

	public DriverManagerConnection(String driver, String url, String userId, String password) throws ClassNotFoundException {
		this.driver = driver;
		this.url = url;
		this.userId = userId;
		this.password = password;
		loadDriver();
	}

	private void loadDriver() throws ClassNotFoundException {
		if (!set.contains(driver)) {
			Class.forName(driver); 
			set.add(driver);	   
		}
	}

	public Connection getConnection() throws SQLException {
		return DriverManager.getConnection(url, userId, password);
	}

}

 定义一个可以生产connection的工厂

package model;

import java.sql.Connection;
import java.sql.SQLException;

import javax.naming.NamingException;

public class ConnectionFactory {
	
	private BuildConnection delegate;

	public ConnectionFactory(String aDriver, String aUrl, String aUserid, String aPassword) throws ClassNotFoundException {
		super();
		delegate = new DriverManagerConnection(aDriver, aUrl, aUserid, aPassword);
	}

	public ConnectionFactory(String userId, String password, String dataSource, String providerUrl, String initialContextFactory) throws NamingException {
		super();
		delegate = new DataSourceConnection(userId, password, dataSource, providerUrl, initialContextFactory);
	}

	public Connection getConnection() throws SQLException {
		Connection connection = delegate.getConnection();
		connection.setAutoCommit(false);
		return connection;
	}
}

 

定义一个管理connection的类

package model;

import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import javax.naming.NamingException;
import tool.DriverNotFound;

public class DatabaseManagement {
	
	private static final String TYPE_JDBC = "jdbc";
	private static final String TYPE_DS = "ds";
	private static final String TYPE = "type";
	private static final String USERID = "userid";
	private static final String PASSWORD = "password";
	private static final String DRIVER = "driver";
	private static final String URL = "url";
	private static final String DATASOURCE = "datasource";
	private static final String PROVIDER_URL = "provider_url";
	private static final String INITIAL_CONTEXT_FACTORY = "initial_context_factory";

	private static final String file = "databaseInformation.properties";
	
	private static String type = null;
	private static String userid = null;
	private static String password = null;
	private static String driver = null;
	private static String url = null;
	private static String datasource = null;
	private static String initialContextFactory = null;
	private static String providerUrl = null;

	static {
		refresh();
	}

	public static void refresh() {
		try {
			InputStream inputStream = DatabaseManagement.class.getClassLoader().getResourceAsStream(file);
			if (inputStream != null) { 
				Properties properties = new Properties();
				properties.load(inputStream);
				type = properties.getProperty(TYPE, type);
				if (type.equalsIgnoreCase(TYPE_JDBC)) {
					userid = properties.getProperty(USERID, userid);
					password = properties.getProperty(PASSWORD, password);
					driver = properties.getProperty(DRIVER, driver);
					url = properties.getProperty(URL, url);
				}
				if (type.equalsIgnoreCase(TYPE_DS)) {
					userid = properties.getProperty(USERID, userid);
					password = properties.getProperty(PASSWORD, password);
					datasource = properties.getProperty(DATASOURCE, datasource);
					providerUrl = properties.getProperty(PROVIDER_URL, providerUrl);
					initialContextFactory = properties.getProperty(INITIAL_CONTEXT_FACTORY, initialContextFactory);
				}
			} 
			inputStream.close();
		} catch (IOException e) {
			e.printStackTrace();
		} 
	}

	public static Connection getConnection() throws SQLException, DriverNotFound {
		ConnectionFactory factory = null;
		try {
			if (type.equalsIgnoreCase(TYPE_JDBC)) {
				factory = new ConnectionFactory(driver, url, userid, password);
			} else {
				factory = new ConnectionFactory(userid, password, datasource, providerUrl, initialContextFactory);
			}
		} catch (ClassNotFoundException e) {
			throw new DriverNotFound(driver);
		} catch (NamingException e) {
			e.printStackTrace();
		}
		return factory.getConnection();
	}

}

 

定义一个异常类

package tool;

public class DriverNotFound extends Exception {
	
	private static final long serialVersionUID = -6926830075212095043L;
	
	private String driver;

	public DriverNotFound(String driver) {
		super("Driver " + driver + " not found");
		setDriver(driver);
	}

	public String getDriver() {
		return driver;
	}

	private void setDriver(String driver) {
		this.driver = driver;
	}
}

 

分享到:
评论

相关推荐

    java模拟spring ioc

    这篇博客“java模拟spring ioc”很可能是探讨如何在没有Spring框架的情况下,使用纯Java代码来实现类似Spring的IOC功能。以下将详细介绍Spring的IOC和DI概念以及如何模拟这些概念。 **依赖注入(Dependency ...

    Java模拟银行系统

    在本项目中,"Java模拟银行系统"是一个典型的软件开发示例,主要使用Java编程语言来构建一个类似于实际银行操作的系统。这个系统可能包括账户管理、交易处理、用户交互等多个核心功能模块,旨在帮助学习者理解面向...

    java模拟电梯上下楼程序

    在Java编程领域,模拟电梯上下楼程序是一种常见的练习,它能帮助开发者理解多线程、同步机制以及事件驱动编程的概念。`ElevatorSimulator`项目就是这样一个实例,它使用Java语言构建,具备良好的用户界面和规范化的...

    java三种工厂模式文档+三个实例.rar

    - 简单工厂模式是一种静态工厂方法模式,它包含一个静态工厂类,负责创建对象。在这个例子中,可能有一个名为`Factory`的类,其中包含一个静态方法,如`createInstance()`,这个方法根据输入参数返回相应的对象实例...

    java模拟数据库事务

    Java模拟数据库事务主要涉及到几个关键知识点,这些知识点在软件开发中尤其在处理数据一致性与并发控制时至关重要。首先,我们来逐一深入理解这些技术。 1) **Socket编程**:Socket是网络通信的基础,它提供了进程...

    Java设计模式之工厂方法的工厂方法实现的源码

    这个Java源码示例是关于工厂方法模式的一个具体实现,特别是工厂方法的工厂方法,即二级工厂模式。 工厂方法模式的核心思想是定义一个创建对象的接口,但让子类决定实例化哪一个类。这样的好处在于隔离了类的实例化...

    Java模拟聊天室.zip

    在本项目中,"Java模拟在线聊天室"是一个基于Java编程语言实现的简易聊天应用程序,旨在提供一个模拟的网络环境,使用户能够进行实时的文字交流。这个程序通常涉及到多线程、网络编程以及用户界面设计等多个Java核心...

    java模拟时钟代码

    Java模拟时钟代码知识点 该项目是一个Java模拟时钟代码,旨在创建一个窗口程序,完成一个模拟钟表和一个数字钟表,并可以通过菜单进行切换。设计要求包括界面具有创意、钟表在正点具有音乐报时功能、钟表具有设置...

    模拟面试 Java 模拟面试 Java

    在Java模拟面试中,面试官通常会关注候选人的基础知识、编程能力、问题解决技巧以及对框架和库的理解。以下是一些可能在Java模拟面试中涉及的关键知识点: 1. **Java基础**:面试通常会从Java的基础概念开始,例如...

    java模拟测试题及答案3套

    1. **基础语法**:Java的基础语法包括变量声明、数据类型(如整型、浮点型、字符型、布尔型)、运算符(算术、关系、逻辑、位运算等)、流程控制(条件语句if/else,循环语句for/while/do-while)和方法定义。...

    java模拟小聊天程序

    例如,`Socket`类提供了`getInputStream`和`getOutputStream`方法,可以分别获取输入流和输出流,用于读取和发送数据。在聊天程序中,数据通常是文本格式,可以使用`DataInputStream`和`DataOutputStream`,它们提供...

    Java简单模拟QQ

    在本项目中,"Java简单...通过以上技术,一个简单的Java模拟QQ应用可以被构建出来,虽然可能无法达到商业级QQ的复杂度和性能,但这个过程对于理解Java网络编程、GUI开发、多线程以及数据库操作等基础概念非常有帮助。

    java抽象工厂模式实例----手机工厂

    这个实例通过模拟手机制造过程,帮助我们理解抽象工厂模式的核心思想:隔离了具体产品类的创建,使得系统可以在不修改已有代码的情况下,添加新的产品类别或品牌。这种灵活性对于应对市场需求的变化至关重要。 总结...

    Java模拟百度相册

    【Java模拟百度相册】项目是一个使用Java Swing库创建的简单桌面应用程序,旨在模拟百度相册的基本功能。在这个项目中,开发者可能运用了Java的基础知识,包括类、对象、继承、多态等核心概念,以及Swing库提供的...

    java模拟电梯运行的程序

    综上所述,Java模拟电梯运行的程序涵盖了多线程编程、事件驱动、状态机设计、数据结构与算法、设计模式以及单元测试等多个核心Java编程概念。通过这样的项目,开发者可以深入理解并发控制、对象行为模拟以及系统优化...

    JAVA实现的模拟电梯系统

    JAVA提供了`synchronized`关键字、`wait()`、`notify()`等方法来控制对共享资源的访问,确保电梯在处理乘客请求时不会发生冲突。 5. **设计模式**:除了状态机,可能还会用到其他设计模式,比如工厂模式用于创建...

    java模拟售票系统程序

    Java模拟售票系统程序是一个用于教学和实践的项目,它涵盖了Java编程语言的基础知识以及面向对象设计的概念。这个系统能够模拟实际的售票流程,包括购票、退票、查询余票等功能,帮助用户理解如何在实际场景中应用...

    java版模拟ATM系统

    Java版的ATM(Automatic Teller Machine)系统模拟是一个经典的编程练习,旨在帮助开发者理解面向对象编程、设计模式以及银行业务流程。在这个项目中,我们将深入探讨如何利用Java语言构建一个功能完备的ATM系统。 ...

    java实现ATM柜员机模拟程序

    Java 实现的ATM柜员机模拟程序是一个典型的面向对象编程示例,它涉及到许多重要的计算机科学和软件工程概念。这个程序通常会包括用户交互、账户管理、交易处理等功能,让我们逐一探讨这些知识点。 1. **Java GUI...

    Java模拟交通路况

    在本项目中,"Java模拟交通路况"是一个基于JAVA编程语言的大作业,旨在通过编程实现对交通路况的模拟。这个项目可能包含多个方面,比如车辆的移动、红绿灯控制、交通规则的遵循等,这些都是计算机科学中的常见问题,...

Global site tag (gtag.js) - Google Analytics