我在eclipse中编写了以下Type4 jdbc连接代码,其中属性文件已用作参考,并且将密钥分配给了user,password,driver和url。有趣的是,当我尝试从属性文件中加载驱动程序时发现了上述错误,但是当我通过将其编写为oracle.jdbc.OracleDriver直接加载驱动程序时,它会找到一个连接并打印该连接。它还会打印引用驱动程序键的值。问题仅在于当我尝试从文件传递与引用相同的东西以加载它时,它会抛出ClassNotFoundException。此外,我还添加了ojdbc14 jar文件,为了进行实验我也尝试过ojdbc6。请让我知道我正在犯什么错误,以及为什么我的Eclipse中会发生此错误。
编写以下代码
public class Type4test {
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
Properties properties = new Properties();
properties.load(new FileInputStream("C:/eclipse/eclipse/workspace/Jdbctype4/src/PropertiesFile/DB.properties"));
//System.out.println("Username "+prop.getProperty("user"));
System.out.println(properties.getProperty("Driver"));
String propertyDriver = properties.getProperty("Driver");
Class.forName(propertyDriver);
//Class.forName("oracle.jdbc.OracleDriver");
Connection con = DriverManager.getConnection(properties.getProperty("url"), properties);
System.out.println(con);
}
}
属性文件如下:
Driver= oracle.jdbc.OracleDriver
url=jdbc:oracle:thin:@localhost:1521:xe
user= System
password= root
我发现的异常是
oracle.jdbc.OracleDriver
Exception in thread "main" java.lang.ClassNotFoundException: oracle.jdbc.OracleDriver
at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
at java.lang.ClassLoader.loadClass(ClassLoader.java:425)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
at java.lang.ClassLoader.loadClass(ClassLoader.java:358)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:190)
at Jdbctype4test.Type4test.main(Type4test.java:21)
最佳答案
当我创建一个.properties
文件并将问题中的内容复制并粘贴到该文件中时,我看到某些行的末尾有空格。它们被保留,而前导空格将被删除:
...
System.out.println("|" + properties.getProperty("Driver") + "|");
...
输出:
|oracle.jdbc.OracleDriver |
^^
因此,您会将无效的类名传递给
Class.forName(propertyDriver);
。从属性文件中的值或
trim()
除去尾随空格(当然,还要除去前导空格):...
String propertyDriver = properties.getProperty("Driver").trim();
....