分享
 
 
 

整合Oracle 10g、Apache 2.0、Php 5

王朝oracle·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

基本介绍

2004年7月13日,php 官方站点正式发布了 PHP 5。Oracle 在 2004 年 8 月公布将在拳头产品 applicationServer 中提供对 PHP 的支持。先是在Oracle Application Server 10g (9.0.4) 提供 mod_php 模块,继而在Oracle Application Server 10g Release 2 (10.1.2) 中提供了 PHP 4.3的版本,接着Oracle JDeveloper 10g 也将提供对 PHP 扩展能力。相信,不久Oracle将正式支持 PHP 5。而随着 Oracle 技术社区的大力推广,也将有更多的开发人员利用 PHP 进行大型数据库引用的开发。

在 OTN 上已经有文档描述如何进行 10g / HTTPD 1.3/ PHP 4 的整合。所以这篇文档将描述如何整合 Oracle 10g、Apache (httpd 2)、PHP 5。便于快速的组建一个开发环境。假如您想对 PHP 的一些新功能(比如PDO)进行一下体验,那么本文可以作为一个开端。

Oracle、Apache、PHP三者之间的关系不妨借用一下这张示意图(原图地址):

本文假定您的 Oracle 10g (服务器或者客户端)已经安装完毕。假如没有安装,请参考这篇文档:

http://www.dbanotes.nethttp://oracle.chinaitlab.com/Install-Oracle10g-RHEL3.htm

确定自己的 Oracle 处于可用状态。

本文所拥的操作系统为 Fedora Core 3 linux,Oracle 版本为10 R1 (10.1.0.2)。

下载所需文件:HTTPD 和 PHP 5

HTTPD - httpd://httpd.apache.org (目前的版本是 2.0.52)

PHP 5 - http://www.php.net (最新版本是 5.0.2)

安装HTTPD

需要说明的是,现在 Apache 社区不推荐把 Apache 2.0 用在产品环境中.

[root@FC3 software]# tar -zxvf httpd-2.0.52.tar.gz

[root@FC3 software]# cd httpd-2.0.52

[root@FC3 httpd-2.0.52]# ./configure --PRefix=/usr/local/apache \

--enable-module=so

[root@FC3 httpd-2.0.52]# make clean

[root@FC3 httpd-2.0.52]# make

[root@FC3 httpd-2.0.52]# make install

[root@FC3 httpd-2.0.52]# /usr/local/apache/bin/apachectl start

[root@FC3 httpd-2.0.52]# /usr/local/apache/bin/apachectl stop

安装说明:第三行指定 Apache 的架构独立的文件安装位置。同时指定将用模块的形式。

假如为了方便的话,可以创建两个脚本控制 Apache 的启动与关闭。

[root@FC3 ~]# vi /bin/startapache

添加如下内容:

#!/bin/sh

ORACLE_HOME=/u01/app/oracle/prodUCt/10.1.0/db_1

ORACLE_SID=TEST

eXPort ORACLE_HOME ORACLE_SID

echo Starting Apache

/usr/local/apache/bin/apachectl start

创建关闭 apache 的脚本:

[root@FC3 ~]# vi /bin/stopapache

添加如下内容:

#!/bin/sh

ORACLE_HOME=/u01/app/oracle/product/10.1.0/db_1

ORACLE_SID=TEST

export ORACLE_HOME ORACLE_SID

echo Starting Apache

/usr/local/apache/bin/apachectl stop

修改文件权限:

[root@FC3 ~] chmod +x /bin/startapache /bin/stopapache

安装 PHP 5

[root@FC3 software]# tar -xjf php-5.0.2.tar.bz2

[root@FC3 software]# cd php-5.0.2

[root@FC3 php-5.0.2]# export ORACLE_BASE=/u01/app/oracle

[root@FC3 php-5.0.2]# export ORACLE_HOME=$ORACLE_BASE/product/10.1.0/db_1

[root@FC3 php-5.0.2]# export ORACLE_SID=TEST

[root@FC3 php-5.0.2]# export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin

[root@FC3 php-5.0.2]# export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib

[root@FC3 php-5.0.2]# ./configure --with-apxs2=/usr/local/apache/bin/apxs \

--with-oci8=$ORACLE_HOME

[root@FC3 php-5.0.2]# make clean

[root@FC3 php-5.0.2]# make

[root@FC3 php-5.0.2]# make install

[root@FC3 php-5.0.2]# cp php.ini-dist /usr/local/lib/php.ini

安装说明:第三到七行其实有些罗嗦了,其目的是控制 root 用户的环境变量,其实也可以直接在 root 用户的.bash_profile文件中制定环境变量。当然了,也可以用 oracle 用户来进行 configure 与 make 。第八行中的 --with-oci8=$ORACLE_HOME 激活 oci8 支持。

接下来需要修改httpd.conf 文件的内容:

[root@FC3 php-5.0.2]# vi /usr/local/apache/conf/httpd.conf

添加如下内容:

LoadModule php5_module modules/libphp5.so

<IfModule mod_php5.c>

AddType application/x-httpd-php .php

</IfModule>

重新启动 apache:

[root@FC3 ]# /bin/stopapache

[root@FC3 ]# /bin/startapache

测试 PHP 模块

测试 PHP 模块是否已经可用。当然是标准办法,写一个包含如下内容的PHP页面 info.php:

<?php phpinfo(); ?>

从浏览器中查看该页面输出内容。

注重,该页面中的内容 Configure Command 那一行中的内容是否包括如下内容:

'--with-apxs2=/usr/local/apache/bin/apxs'

'--with-oci8=/u01/app/oracle/product/10.1.0/db_1'

注重:在测试之后,出于安全的考虑,请把该文件删除

测试 PHP 的 oci

写一个简单的页面测试 oci 是否可用 (Just a copy sample from OTN):

<?php

$db_conn = ocilogon( "scott", "tiger","TEST" );

$cmdstr = "select ename, sal from emp";

$parsed = ociparse($db_conn, $cmdstr);

ociexecute($parsed);

$nrows = ocifetchstatement($parsed, $results);

echo "<Html><head><title>Oracle PHP Test</title></head><body>";

echo "<center><h2>Oracle PHP Test</h2><br>";

echo "<table border=1 cellspacing='0' width='50%'>\n\<tr>\n";

echo "<td><b>Name</b></td>\n<td><b>Salary</b></td>\n</tr>\n";

for ($i = 0; $i < $nrows; $i++ )

{

echo "<tr>\n";

echo "<td>" . $results["ENAME"][$i] . "</td>";

echo "<td>$ " . number_format($results["SAL"][$i], 2). "</td>";

echo "</tr>\n";

}

echo "<tr><td colspan='2'> Number of Rows: $nrows</td></tr></table>";

echo "<br><em>If you see data, then it works!</em><br></center></body></html>\n";

?>

说明:上例中,scott/tiger分别为数据库的用户名字和密码,TEST为数据库连接串名字。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有