php执行ociconnect,php – oci_connect()仅适用于命令行

好的,所以我对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文件:

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脚本的开头(我通过/etc/init.d/apache2 start启动apache).

Apache从运行oinstall和dba组的wwwrun用户运行:

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:~ #

可能的问题

我在phpinfo()的Environment部分没有任何环境变量;输出 – 这可能是问题吗?如果是,我该如何解决这个问题?这是某种安全问题吗?我已经阅读了启用SELinux的问题,但我没有,我的防火墙已关闭.

解?

任何帮助将不胜感激!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值