I am trying to make a jdbc oci connection with oracle 11g that uses os authentication
i created a test console application to test the connection on any client machine
I developed the application on a machine with jdk 6 and used the jar ojdbc6.jar in the project .
The code I use to connect to the database is as follows:
OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();
I try to run this application from the client machine on which oracle11g is installed, and the oracle house is set to the path: C: \ orant \ jdk \ bin
also the path: C: \ orant \ bin contains oci.dll and does not contain ocijdbc11.dll
the client installed jre7 and does not have jdk.
when I try to run the above code on an authenticated client machine in the oracle database, I get the following exception:
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)
please advise how I can fix this exception.
source
share