首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >线程Jdbctype4test.Type4test.main(Type4test.java:21) java.lang.ClassNotFoundException异常: oracle.jdbc.OracleDriver main

线程Jdbctype4test.Type4test.main(Type4test.java:21) java.lang.ClassNotFoundException异常: oracle.jdbc.OracleDriver main
EN

Stack Overflow用户
提问于 2016-01-26 23:34:13
回答 1查看 367关注 0票数 1

我在eclipse中编写了以下Type4 jdbc连接代码,其中属性文件被用作引用,并将密钥分配给用户、密码、驱动程序和url。有趣的是,当我试图从属性文件加载驱动程序时,我发现了上面的错误,但是当我通过将驱动程序编写为oracle.jdbc.OracleDriver来直接加载驱动程序时,它会找到一个连接并打印该连接。它还打印的值引用的驱动程序的问题是,只有当我尝试传递相同的东西作为引用从文件加载它抛出ClassNotFoundException.Also我已经添加了ojdbc14 jar文件,为了实验我也尝试了ojdbc6。请让我知道我犯了什么错误,为什么这个错误会出现在我的Eclipse中。

下面的代码是编写的

代码语言:javascript
复制
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);
  }
}

属性文件如下所示:

代码语言:javascript
复制
Driver= oracle.jdbc.OracleDriver 
url=jdbc:oracle:thin:@localhost:1521:xe
user= System
password= root 

我发现的例外情况是

代码语言:javascript
复制
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)
EN

回答 1

Stack Overflow用户

发布于 2016-01-26 23:47:07

当我创建一个.properties文件并将问题中的内容复制粘贴到该文件中时,我看到其中一些行具有尾随空格。它们将被保留,而前导空格将被删除:

代码语言:javascript
复制
  ...
  System.out.println("|" + properties.getProperty("Driver") + "|");
  ...

输出:

代码语言:javascript
复制
|oracle.jdbc.OracleDriver  |
                         ^^

因此,您将向Class.forName(propertyDriver);传递无效的类名。

从属性文件的值中删除尾随空格(当然也要删除前导空格),或者对它们执行trim()操作:

代码语言:javascript
复制
...    
String propertyDriver = properties.getProperty("Driver").trim();
....
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35017632

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档