java.lang.UnsatisfiedLinkError:java中没有ocijdbc11.library.path

Mah*_*leh 5 java oracle jdbc oracle-call-interface

我试图让JDBC OCI连接的Oracle 11g使用OS验证

我做了一个示例控制台应用程序来测试某些客户端计算机上的连接

我在具有jdk 6的机器上开发了应用程序,并在项目中使用了jar ojdbc6.jar.

我用来连接数据库的代码如下:

OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();
Run Code Online (Sandbox Code Playgroud)

我正在尝试从安装了oracle11g的客户端计算机上运行此应用程序,并且在路径上将oracle主目录设置为: C:\ orant\jdk\bin

路径:C:\ orant\bin包含oci.dll,不包含ocijdbc11.dll

客户端安装了jre7并且没有jdk.

当试图在os验证到oracle数据库的客户端机器上运行上面的代码时,我遇到以下异常:

Exception in thread "main" java.lang.UnsatisfiedLinkError: no ocijdbc11 in java.
library.path
        at java.lang.ClassLoader.loadLibrary(Unknown Source)
        at java.lang.Runtime.loadLibrary0(Unknown Source)
        at java.lang.System.loadLibrary(Unknown Source)
        at oracle.jdbc.driver.T2CConnection$1.run(T2CConnection.java:3178)
        at java.security.AccessController.doPrivileged(Native Method)
        at oracle.jdbc.driver.T2CConnection.loadNativeLibrary(T2CConnection.java
:3174)
        at oracle.jdbc.driver.T2CConnection.logon(T2CConnection.java:233)
        at oracle.jdbc.driver.PhysicalConnection.<init>(PhysicalConnection.java:
508)
        at oracle.jdbc.driver.T2CConnection.<init>(T2CConnection.java:133)
        at oracle.jdbc.driver.T2CDriverExtension.getConnection(T2CDriverExtensio
n.java:53)
        at oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:510)
        at oracle.jdbc.pool.OracleDataSource.getPhysicalConnection(OracleDataSou
rce.java:275)
        at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java
:206)
        at oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java
:156)
        at auth.Main.main(Main.java:42)
Run Code Online (Sandbox Code Playgroud)

请告知我如何解决此异常.

Mah*_*leh 0

在这篇文章中,我能够使用 jdbc 成功建立与 Oracle 数据库的操作系统连接:

如何通过os认证连接oracle数据库?