6

OK、それで私はoci、apache、php、suseでこのひどい問題を抱えています。まず、バージョン:

PHP 5.3.15 (cli)
Apache/2.2.22 (Linux/SUSE)
OCI8 1.4.9
SUSE 12.2 32 bit
Oracle client 10.2.0.4

問題

私は本当に単純なphpファイルを持っています:

<?php
    error_reporting(E_ALL);
    ini_set('display_errors', '1');
    oci_connect('user', 'passwd', 'host/sid');
?>

コマンドラインから実行すると、正常に実行されます。

machine:~ # php oci.php
machine:~ #

しかし、ブラウザで実行すると、次のようになります。

Warning: oci_connect() [function.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

Apache構成

私はこの問題にしばらく苦労していて、apacheの構成が正しいと確信しています。

apacheプロセスを開始する前に、必要なすべての変数をエクスポートします-追加しました

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/path/to/oracle/home/lib; export LD_LIBRARY_PATH
ORACLE_HOME=/path/to/oracle/home; export ORACLE_HOME
TNS_ADMIN=/path/to/oracle/home/network/admin; export TNS_ADMIN
NLS_LANG=POLISH_POLAND.EE8MSWIN1250; export NLS_LANG

スクリプトの最初に/etc/init.d/apache2(私はapacheをで開始し/etc/init.d/apache2 startます)。

Apacheは、以下のグループに所属wwwrunするユーザーから実行されます。oinstalldba

machine:~ # cat /etc/apache2/uid.conf
User wwwrun
Group www
machine:~ # id wwwrun
uid=30(wwwrun) gid=8(www) groups=8(www),113(oinstall),114(dba)
machine:~ # l $ORACLE_HOME
total 216
drwxr-xr-x 48 oracle oinstall 4096 Jan 25 17:07 ./
drwxrwxr-x  3 oracle oinstall 4096 Jan 25 17:01 ../
...
machine:~ #

考えられる問題

出力のEnvironmentセクションに環境変数がありません-これが問題になる可能性がありますか?phpinfo();はいの場合、どうすればこれを修正できますか?それはある種のセキュリティ問題ですか?SELinuxを有効にした場合のそのような問題について読んだことがありますが、それがなく、ファイアウォールがオフになっています。

解決?

どんな助けでも大歓迎です!

4

4 に答える 4

6

問題が解決しました!これらのOracle環境の設定セクション)手順とこのスレッドに対するken_yapの回答に感謝します。

Apacheの環境/etc/sysconfig/apache2セクションに変数を配置するには、ファイルに変数を追加する必要がありますLD_LIBRARY_PATH=/path/to/oracle/lib

于 2013-01-31T13:24:30.423 に答える
3

別の解決策(rootアクセスを必要としない)は、phpページに次の行を追加することです。

putenv("ORACLE_HOME=/opt/app/oracle/product/11.2.0/db_1");
putenv("LD_LIBRARY_PATH=/opt/app/oracle/product/11.2.0/db_1/lib:/lib:/usr/lib");

よろしく

于 2013-06-17T20:07:32.593 に答える
0

Debianユーザーの場合-ファイルを編集

/etc/apache2/envvars

ファイルの終わりに、OCIライブラリへのリンクを追加します-例:

export LD_LIBRARY_PATH=/opt/oracle/instantclient_12_2
于 2018-09-10T11:39:13.647 に答える
0

Centos7の別のアプローチnginx

$ sudo vim /etc/ld.so.conf.d/oracle-instantclient.conf

// Add path to oracle client lib, the XX is the version, ex: /usr/lib/oracle/XX/client64/lib 

$ sudo ldconfig
$ sudo service php-fpm restart

終わり!

于 2019-01-10T10:56:44.390 に答える