gpt4 book ai didi

java - 线程中的异常 "main"java.lang.ClassNotFoundException : oracle. jdbc.OracleDriver Jdbctype4test.Type4test.main(Type4test.java:21)

转载 作者:太空宇宙 更新时间:2023-11-04 13:00:01 25 4
gpt4 key购买 nike

我在 eclipse 中编写了以下 Type4 jdbc 连接代码,其中使用属性文件作为引用,并将 key 分配给用户、密码、驱动程序和 url 。有趣的是,当我尝试从属性文件加载驱动程序时,我发现上述错误,但是当我通过将其写入 oracle.jdbc.OracleDriver 直接加载驱动程序时,它会找到一个连接并打印该连接。它还打印引用驱动程序 key 的值。问题是,只有当我尝试传递与文件中的引用相同的内容来加载它时,它才会抛出 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();
....

关于java - 线程中的异常 "main"java.lang.ClassNotFoundException : oracle. jdbc.OracleDriver Jdbctype4test.Type4test.main(Type4test.java:21),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35017632/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com