OS認証を使用するOracle 11gへのjdbc oci接続を作成しようとしています
クライアントマシンで接続をテストするためのサンプルコンソールアプリケーションを作成しました
jdk 6を搭載したマシンでアプリケーションを開発し、プロジェクトでjar ojdbc6.jarを使用しました。
データベースへの接続に使用しているコードは次のとおりです。
OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();
oracle11g がインストールされているクライアント マシンからこのアプリケーションを実行しようとしています。Oracle ホームは次のパスに設定されています: C:\orant\jdk\bin
また、パス: C:\orant\binにはoci.dllが含まれ、 ocijdbc11.dllは含まれません。
クライアントには jre7 がインストールされており、jdk はありません。
Oracleデータベースに対してos認証されたクライアントマシンで上記のコードを実行しようとすると、次の例外が発生します。
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)
この例外を修正する方法を教えてください。