线程" main"中的例外情况java.lang.ClassNotFoundException:oracle.jdbc.OracleDriver Jdbctype4test.Type4test.main(Type4test.java:21)

时间:2016-01-26 15:34:13

标签: java eclipse oracle jdbc

我在eclipse中编写了以下Type4 jdbc连接代码,其中属性文件已被用作引用,并且密钥被分配给用户,密码,驱动程序和URL。有趣的是,当我尝试从属性文件加载驱动程序时,我发现上述错误,但是当我通过将其编写为oracle.jdbc.OracleDriver直接加载驱动程序时,它会找到连接并打印连接。它还打印引用驱动程序键的值。问题是当我尝试从文件传递相同的东西来加载它时抛出ClassNotFoundException.Also我已经添加了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)

1 个答案:

答案 0 :(得分:0)

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

  ...
  System.out.println("|" + properties.getProperty("Driver") + "|");
  ...

输出:

|oracle.jdbc.OracleDriver  |
                         ^^

因此,您会将无效的班级名称传递给Class.forName(propertyDriver);

从属性文件中的值中移除尾随空格(并确保也是前导空格),或者trim()它们:

...    
String propertyDriver = properties.getProperty("Driver").trim();
....