程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> Linux下PHP開啟Oracle支持(oci8)

Linux下PHP開啟Oracle支持(oci8)

編輯:Oracle教程

Linux下PHP開啟Oracle支持(oci8)


使用php的常見問題是:編譯php時忘記添加某擴展,後來想添加擴展,但是因為安裝php後又裝了一些東西如PEAR等,不想刪除目錄重裝,那麼此時就需要自己重新增加某模塊支持了,Linux操作系統下可以用phpize給PHP動態添加擴展.下面就以擴展模塊 oci8為例(php連接oracle數據庫需要改擴展支持)做簡單的說明.(以下所有資源可以訪問http://download.csdn.net/detail/haiqiao_2010/8294513 進行統一下載)

 

1.下載Oracle客戶端程序包,其中包含OCI、OCCI和JDBC-OCI等相關文件

1.1 根據Linux系統選擇對應的軟件,我的為32位系統,所以下載如下文件:

 

oracle-instantclient11.2-basic-11.2.0.3.0-1.i386.rpm

oracle-instantclient11.2-devel-11.2.0.3.0-1.i386.rpm

1.2下載地址: http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html (Oracle官網下載需要注冊用戶)

2.安裝oracle客戶端,運行以下命令即可:

 

rpm -ivh oracle-instantclient11.2-basic-11.2.0.3.0.i386.rpm

rpm -ivh oracle-instantclient11.2-devel-11.2.0.3.0.i386.rpm

3.安裝oci8 php擴展

3.1 下載oci8-1.4.10.tgz

下載地址:http://pecl.php.net/get/oci8-1.4.10.tgz

3.2 把下載文件上傳至linux服務器,並進行解壓

命令:tar zxvf oci8-1.4.10.tgz#解壓

3.3 轉到解壓目錄

命令:cd oci8-1.4.10

3.4 使用phpize准備 PHP 外掛模塊的編譯環境,會根據指定的環境變量生成編譯時需要的makefile,phpize是屬於php-devel的內容,所以centos下只要運行yum install php-devel進行安裝即可 (注意:/usr/local/php/bin/phpize 為我的php目錄,不同則需改之;如果是64位的系統,client改成client64)

/usr/local/php/bin/phpize CFLAGS="-I/usr/lib/oracle/11.1/client" CXXFLAGS="-I/usr/lib/oracle/11.1/client"

3.5 編譯,安裝

 

要有與現有php完全相同的php壓縮包。我用的是php-5.5.3.tar.gz。展開後進入裡面的ext/oci8目錄下,

然後執行命令: /usr/local/php/bin/phpize #這是一個可執行的文本文件,要確保它在系統中

會發現當前目錄下多了一些configure文件,

如果沒報錯,則運行命令;

./configure --with-php-config=/usr/local/php/bin/php-config --with-oci8=/usr/lib/oracle/11.1/client

 

注意要先確保/usr/local/php/bin/php-config存在。如果你的php安裝路徑不是默認的,要改。

再運行以下命令 ,然後它告訴你一個目錄,你把該目錄下的oci8.so拷貝到你php.ini中的extension_dir指向的目錄中

make
make install

需要強調的是make的時候會報錯,顯示各種找不到庫文件,需要對makefile文件進行修改加入oralce的運行庫地址

打開makefile,尋找INCLUDE,形式如下:

INCLUDES = -I/usr/local/php/include/php -I/usr/include/oracle/10.2.0.3/client

然後在末尾加上="-I/usr/lib/oracle/11.1/client,然後重新make就會成功了。

4. 修改PHP.ini(/usr/local/php/etc/php.ini)

在extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/"後增加一行:

extension = "oci8.so"

注意:要確保/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/ 該目錄下有oci8.so文件

5.重啟apache,讓oci生效

6.在web目錄下創建phpinfo.php文件在其中輸入一下內容,並通過web訪問

 

<?php
	phpinfo();
?>

如果找到OCI8的部分就說明OCI安裝正常了,如下圖所示\

\

說明oci8安裝成功,接下來就可以使用php訪問oracle數據庫了

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved