有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

线程“main”java中的eclipse异常。lang.ClassNotFoundException:oracle。jdbc。OracleDriver Jdbctype4test。类型4测试。main(Type4test.java:21)

我在eclipse中编写了以下Type4JDBC连接代码,其中属性文件被用作引用,密钥被分配给用户、密码、驱动程序和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)

共 (1) 个答案

  1. # 1 楼答案

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

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

    输出:

    |oracle.jdbc.OracleDriver  |
                             ^^
    

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

    从属性文件中的值中删除尾随空格(当然也包括前导空格),或者trim()删除它们:

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