0

可能重复:
使用 Oracle Wallet 从 PHP 连接到 Oracle DB

我们计划实施 Oracle Wallet。它从 sqlplus 工作,如下所示。这表明钱包功能正在运行。

    export ORACLE_HOME=/afs/engg/g/lcls/package/oracle/product/11.1.0.6/client
    export PATH=$ORACLE_HOME/bin:${PATH}
    export TNS_ADMIN=/afs/engg/g/lcls/tools/oracle/wallets/engg_reader


    $ sqlplus /@enggdev
    SQL> show user
    USER is "ENGG_READER"

到目前为止,我还没有成功使它从 php 工作。我们安装了带有 OCI8 扩展的 php。请特别指导我 oci_connect 命令及其语法。

这是我的 php 文件 -

    <?php
    // Create connection to Oracle
    PutEnv("ORACLE_HOME=/afs/engg/g/lcls/package/oracle/product/11.1.0.6/client");
    PutEnv("TNS_ADMIN=/afs/engg/g/lcls/tools/oracle/wallets/engg_reader");


    $conn = oci_connect("/", "", "$TNS_ADMIN", null, OCI_CRED_EXT);



     if (!$conn) {
     $m = oci_error();
     echo $m['message'], "\n";
     exit;
     }
     else {
     print "Connected to Oracle!\n";
     }
     // Close the Oracle connection
     oci_close($conn);
     ?>

当我执行命令时$ /mccelog/package/php/php-5.4.7/bin/php connect4.php

Warning: oci_connect(): OCIEnvNlsCreate() failed. There is something wrong 
with your system - please check that ORACLE_HOME and LD_LIBRARY_PATH are set and 
point to the right directories in /afs/engg/u/cd/divekar/technical/connect4.php on
line 7

请注意,我已正确设置ORACLE_HOMELD_LIBRARY_PATH. 第 7 行是导致该错误的 oci_connect 字符串。如何使用 oci8/oci_connect 连接到 Oracle 数据库?

提前谢谢你。问候。-Shashi Divekar

4

1 回答 1

0

谢谢你。你的回答很有用。我试图分配积分,但它不允许我分配积分。我做了一些实验,现在这对我有用。

我设置了一些环境变量,然后运行 ​​php 脚本。

导出 ORACLE_HOME=/nfs/lcls/package/oracle/product/11.1.0.6/client

导出 TNS_ADMIN=/nfs/lcls/tools/oracle/wallets/elog_reader

我从命令行运行以下测试 php 脚本,它现在正在工作。至少现在我有 OCI8 和 Oracle 钱包一起工作。

php连接.php

<?php
// Create connection to Oracle

$conn = oci_connect("/", "", "MCCODEV", null, OCI_CRED_EXT);
if (!$conn) {
$m = oci_error();

echo $m['message'], "\n";
exit;
}
else {
     print "Connected to Oracle!\n";
      }
 // Close the Oracle connection
 oci_close($conn);
 ?>

再次感谢您的帮助和提供的非常好的信息。我还将更新我的 stackoverflow.com 帖子。

问候。-Shashi Divekar

于 2012-10-19T04:48:01.347 回答