java.lang.UnsatisfiedLinkError:java中没有ocijdbc11。库路径

java.lang.UnsatisfiedLinkError:java中没有ocijdbc11。库路径,java,oracle,jdbc,oracle-call-interface,Java,Oracle,Jdbc,Oracle Call Interface,我正在尝试与使用操作系统身份验证的oracle 11g建立jdbc oci连接 我制作了一个示例控制台应用程序来测试某台客户机上的连接 我在拥有jdk6的机器上开发了应用程序,并在项目中使用了jarojdbc6.jar 我用于连接数据库的代码如下所示: OracleDataSource ods = new OracleDataSource(); String tnsName="Prod"; ods.setURL("jdbc:oracle:oci:/@"+tnsName); Connection

我正在尝试与使用操作系统身份验证的oracle 11g建立jdbc oci连接

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

我在拥有jdk6的机器上开发了应用程序,并在项目中使用了jarojdbc6.jar

我用于连接数据库的代码如下所示:

OracleDataSource ods = new OracleDataSource();
String tnsName="Prod";
ods.setURL("jdbc:oracle:oci:/@"+tnsName);
Connection conn = ods.getConnection();
我正在尝试从安装了oracle11g的客户端计算机上运行此应用程序,并且oracle home的路径设置为:C:\orant\jdk\bin

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

客户端安装了jre7,但没有jdk

尝试在通过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)
线程“main”java.lang.UnsatisfiedLinkError中出现异常:java中没有ocijdbc11。 库路径 位于java.lang.ClassLoader.loadLibrary(未知源) 位于java.lang.Runtime.loadLibrary0(未知源) 位于java.lang.System.loadLibrary(未知源) 位于oracle.jdbc.driver.T2CConnection$1.run(T2CConnection.java:3178) 位于java.security.AccessController.doPrivileged(本机方法) 位于oracle.jdbc.driver.T2CConnection.loadNativeLibrary(T2CConnection.java :3174) 位于oracle.jdbc.driver.T2CConnection.logon(T2CConnection.java:233) 位于oracle.jdbc.driver.PhysicalConnection。(PhysicalConnection.java: 508) 位于oracle.jdbc.driver.T2CConnection(T2CConnection.java:133) 位于oracle.jdbc.driver.T2CDriverExtension.getConnection(T2CDriverExtensio n、 爪哇:53) 位于oracle.jdbc.driver.OracleDriver.connect(OracleDriver.java:510) 在oracle.jdbc.pool.OracleDataSource.getPhysicalConnection(OracleDataSou rce.java:275) 在oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java :206) 在oracle.jdbc.pool.OracleDataSource.getConnection(OracleDataSource.java :156) 位于auth.Main.Main(Main.java:42)
请告知我如何修复此异常。

在本文中,我使用jdbc成功地实现了到oracle数据库的操作系统连接:

如果使用OCI url(
“jdbc:oracle:OCI://@”+tnsName
),则类路径上需要oracle客户端库。因此,您需要在计算机上安装oracle客户端

但是,如果使用精简驱动程序并按如下所示指定url,则不需要oracle客户端

"jdbc:oracle:thin:@"+dbServer+":"+port+":"+SID; 

尝试在usr/share/tomcat/conf/tomcat.conf中为ld\u路径设置正确的值:

LD_LIBRARY_PATH="/usr/lib/oracle/11.2/client64/lib:/usr/lib64"

如果你在Jboss 6.1.0中使用Eclipse,会显示错误 线程“main”java.lang.UnsatifiedLinkError中出现异常:java中没有ocijdbc11。 库路径 解决方案: 从oracle\product\11.2.0\client\u 1\BIN复制ocijdbc11.dll并粘贴到


D:\jboss-6.1.0.Final\bin\native

我认为您遇到了这个问题,因为您使用的是JRE 1.6或更低版本的Java和type-2驱动程序。请用JRE 1.7或JRE 1.8替换您的JRE 1.6构建路径。这将解决问题

请按照以下步骤操作:

  • 右键单击项目文件夹
  • 点击属性
  • 单击java构建路径
  • 从库中选择“jre系统库”,它是jre 1.6或更低版本,并将其删除,因为这正成为原因的来源
  • 现在单击添加库
  • 单击jre系统库
  • 单击下一步
  • 单击environment(环境)按钮,选择执行环境为JavaSE-1.8(jre1.8.0_144),然后按ok
  • 单击已安装的jre按钮
  • 从中选择jre1.8(如果jre1.8不存在,请单击添加按钮并添加)
  • 单击Finish
  • 单击“确定”
  • 瓦拉!您将发现您的代码正在运行

  • 作为Oracle安装的一部分,您应该有
    ocijdbc.dll
    ;我不确定它在Windows中的位置,但在Linux中它位于
    ORACLE\u HOME/lib
    下。我想,您也需要
    路径中的任何目录。我没有环境来检查,所以我不太确定。或者可能有效…可能是32位64位的问题。dll和Java的比特数是多少?顺便说一句:
    ocijdbc11
    是一个符号名,它不一定与文件名匹配。@Alex Poole,@Mark Rotterveel我在客户端计算机上找不到ocijdbc11.dll?请建议尝试的解决方案。@Alex Poole,@Mark Rotterveel我认为还有其他方法可以在不需要dll的情况下建立连接,对吗?