Rumah >Java >javaTutorial >新Java运动:测试驱动开发3---用户注册3

新Java运动:测试驱动开发3---用户注册3

黄舟
黄舟asal
2016-12-30 13:15:081206semak imbas

直到目前为止,我们还没有接触到用户注册的实质性问题,即向数据库中添加用户。我们现在来处理这个需求。

首先需要确定数据库访问所用的技术,这里可以选择Hibernate、JPA或JDBC。相信绝大多数应用都是采用Hibernate来作为数据库访问技术,另外一部分人可能会选择JPA,但是我们在这里选择JDBC。原因比较简单,底层的东西看上去好像比较复杂,但是一旦掌握,由于它的内容少,相对来讲更容易精通。而这种O-R映射模型,添加了许多抽象概念和细节,我们通常只看这些架构冰山的一角,而如果想掌握冰山下面的东西,难度比直接掌握JDBC难上几个数量级。

另外,由于我们测试驱动开发的架构,我们想要转换为其他架构,可以对现有代码进行重构,在测试用例的保证下,我们可以放心地对代码进行修改。

好了,我们首先用DAO模式,定义数据库访问接口类UserDao,代码如下所示:

public interface UserDao {  
    public long registerUser(Map<String, Object> userInfo);  
}

一般来讲,我们使用Mysql数据库,所以定义Dao的实现类UserMysqlDao,代码如下所示:

public class UserMysqlDao implements UserDao {  
    @Override  
    public long registerUser(Map<String, Object> userInfo) {  
        // TODO Auto-generated method stub  
        return 0;  
    }

我们当然不希望使用者来确定所用的数据库,然后实例化对应的实现类,为此我们需要采用工厂模式,引入DaoFactory类,代码如下:

public class DaoFactory {  
    public static UserDao getUserDao() {  
        UserDao dao = null;  
        switch (dbms) {  
        case "mysql":  
            dao = new UserMysqlDao();  
            break;  
        }  
        return dao;  
    }  
      
    public static String getDbms() {  
        return dbms;  
    }  
  
    public static void setDbms(String dbms) {  
        DaoFactory.dbms = dbms;  
    }  
  
    private static String dbms = "mysql";  
}

由上面的代码可以看出,调用者只需调用DaoFactory.getUserDao()即可获取实现类了。

下面就是数据库连接的问题,我们希望在Jboss等应用服务器上运行时采用数据库连接池,而在单元测试中使用DriverManager,所以需要定义一个DataSource的封装类JdbcDs来处理上述情况,代码如下所示:

public class JdbcDs {	
	public static Connection getConnection() throws SQLException {
		Connection conn = null;
		if (iDebug <= 0) {
			conn = appDs.getConnection();
		} else {
			try {
				Class.forName("com.mysql.jdbc.Driver").newInstance();
			} catch (InstantiationException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IllegalAccessException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (ClassNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			Properties connectionProps = new Properties();
		    connectionProps.put("user", "root");
		    connectionProps.put("password", "yantao");
		    conn = DriverManager.getConnection(
	                   "jdbc:" + "mysql" + "://" +
	                   "localhost" +
	                   ":" + 3306 + "/XrcjDb",
	                   connectionProps);
		}
		return conn;
	}

	public static int iDebug = 1;
	public final static String APP_DS = "java:jboss/datasources/XcgDS";
	private static DataSource appDs = null; 
	static{
		if (null == appDs) {
			Properties env = new Properties();
			try {
				InitialContext ictx = new InitialContext(env);
				appDs = (DataSource)ictx.lookup(APP_DS);
			} catch (NamingException e1) {
				// TODO Auto-generated catch block
				e1.printStackTrace();
			}
		}
	}
	
}

当进行单元测试时,只需将iDebug置为1即可。否则会使用数据库连接池。

做完所有的准备工作,下面就可以正式进行数据库功能开发了。

 以上就是新Java运动:测试驱动开发3---用户注册3的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn