[英]java.lang.ExceptionInInitializerError in Connection Factory
您好,下面是我的代码,它将用作Connection Factory类。 但是我正在获取java.lang.ExceptionInInitializerError。 请咨询如何解决? 我认为这是由于静态块造成的陷阱,但不知道这到底是什么。
package j2ee.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.Properties;
public class ConnFactory
{
public static Properties prop;
static
{
prop=new Properties();
try {
prop.load(ConnFactory.class.getClassLoader().getResourceAsStream("DBConfig.properties"));
} catch (Exception e) {
e.printStackTrace();
}
}
private static ConnFactory instance = new ConnFactory();
public static final String URL = prop.getProperty("DEVURL");
public static final String USER = prop.getProperty("DEVUSER");
public static final String PASSWORD = prop.getProperty("DEVPASSWORD");
public static final String DRIVER_CLASS = prop.getProperty("DEVDRIVER_CLASS");
private ConnFactory() {
try {
Class.forName(DRIVER_CLASS);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
private Connection createConnection() {
Connection connection = null;
try {
connection = DriverManager.getConnection(URL, USER, PASSWORD);
} catch (Exception e) {
System.out.println("ERROR: Unable to Connect to Database.");
}
return connection;
}
public static Connection getConnection() {
return instance.createConnection();
}
public static void main(String a[])
{
Connection test=ConnFactory.getConnection();
System.out.println("Done");
}
}
错误是:
Caused by: java.lang.NullPointerException
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:188)
at j2ee.dao.ConnFactory.<init>(ConnFactory.java:28)
at j2ee.dao.ConnFactory.<clinit>(ConnFactory.java:20)
private static ConnFactory instance = new ConnFactory(); // DRIVER_CLASS is null at this point
...
public static final String DRIVER_CLASS = ...;
您创建的实例ConnFactory
之前DRIVER_CLASS
被初始化,因此DRIVER_CLASS
是null
的的构造ConnFactory
。
您需要颠倒这些静态字段声明的顺序:
public static final String DRIVER_CLASS = ...;
...
private static ConnFactory instance = new ConnFactory()
实际上,我认为最好完全消除这些静态字段。 只需使其变为非静态,然后在构造函数中对其进行初始化即可。
您还可以将Properties
的实例传递给构造器,以使连接创建与连接属性的存储脱钩。 如果这样做,您将能够在不同情况下使用不同的属性集(例如,用于测试和生产环境)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.