WEB开发网      婵犵數濞€濞佳囧磹婵犳艾鐤炬い鎰堕檮閸嬬喐銇勯弽銊с€掗梻鍕閺岋箑螣娓氼垱笑闂佽姘﹂褔婀佸┑鐘诧工妤犲憡绂嶉崜褏纾奸弶鍫涘妼缁楁岸鏌熷畡鐗堝殗闁诡喒鏅犲畷褰掝敃閵堝棙顔忔繝鐢靛仦閸ㄥ爼骞愰幘顔肩;闁规崘绉ぐ鎺撳亹闁绘垶锕╁Λ鍕⒑閹肩偛濡奸悗娑掓櫇缁顓兼径妯绘櫇闂佹寧绻傞弻濠囨晝閸屾稓鍘甸柣搴㈢⊕閿氶柣蹇ョ稻缁绘繃绻濋崘銊т紝闂佽鍨伴崯鏉戠暦閻旂⒈鏁傞柛鈾€鏅欑槐妯衡攽閻愬樊鍤熷┑顔藉劤铻為柛鏇ㄥ墯閸欏繘鏌嶉崫鍕櫣缂佲偓婢跺绠鹃柟瀛樼箘閿涘秵顨ラ悙顏勭伈闁诡喖缍婂畷鎯邦槻婵℃彃顭烽弻娑㈠Ω閵夈儺鍔夌紓浣稿€哥粔褰掑极閹剧粯鏅搁柨鐕傛嫹 ---闂傚倷鐒︾€笛兠洪埡鍛闁跨噦鎷�
开发学院WEB开发PHP Windows 2003 下 PHP5.2.5 + Apache2.2.8 + Oracl... 阅读

Windows 2003 下 PHP5.2.5 + Apache2.2.8 + Oracle10g/11g 的配置

 2009-10-24 11:28:33 来源:WEB开发网 闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹闂傚倷绀侀幉锟犲垂閻㈠灚宕查柟鎵閸庡秵銇勯幒鎴濃偓鐢稿磻閹炬枼妲堟繛鍡楃С濞岊亞绱撻崒姘扁枌闁瑰嚖鎷�婵犵數濮幏鍐川椤撴繄鎹曢梻渚€娼уú銈吤洪妸鈺佺劦妞ゆ帊鑳堕埊鏇㈡煏閸モ晛浠х紒杈╁仱閺佹捇鏁撻敓锟�闂傚倷绶氬ḿ褍螞閹绢喖绠柨鐕傛嫹  闂傚倷鑳舵灙缂佺粯顨呴埢宥夊即閵忕姵鐎梺缁樺姈椤愮厧鈽夊Ο閿嬬€婚梺褰掑亰閸撴稑鈻斿鑸碘拺闁告稑饪村▓鏃€绻涚仦鍌氬闁崇粯鎹囬獮瀣攽閹邦剚顔傛俊鐐€栧濠氬储瑜忛幉鎾晸閿燂拷
核心提示: php 和 Apache 已经配置完毕,成功集成在一起工作(相关文章和经验介绍参见本人博客:http://blog.why100000.com),Windows 2003 下 PHP5.2.5 + Apache2.2.8 + Oracle10g/11g 的配置,但为了使 PHP 能够操作 Oracle 数据库,仅仅

   php 和 Apache 已经配置完毕,成功集成在一起工作(相关文章和经验介绍参见本人博客:http://blog.why100000.com)。但为了使 PHP 能够操作 Oracle 数据库,仅仅打开 php.ini 文件的 php_oci8.dll 扩展是不够的,因为 PHP 的扩展也是调用 Oracle 的底层 API 来工作的(包含在 oci.dll 文件中),所以还必须安装 Oracle 的 client 函数库。

   到网址
http://www.oracle.com/technology/software/tech/oci/instantclient/htdocs/winsoft.html下载 instantclient-basic-win32。注意不是 instantclient-basiclite-win32,因为 basiclite 只支持英文和西欧字符集。instantclient-basic-win32 目前版本是 Version 11.1.0.7.0,即下载文件 instantclient-basic-win32-11.1.0.7.0.zip 即可。

   解压该软件包,比如放到 D:\instantclient_11_1 文件夹下,将这个路径添加到系统变量 PATH 中去,最好添加在路径的开头。再在系统变量里面加一个 TNS_ADMIN 变量,值也设为C:\instantclient_11_1。最后把 php.ini 里面的 extension=php_oci8.dll 打开,为了支持 PDO,也可以打开 extension=php_pdo_oci.dll 和 extension=php_pdo_oci8.dll,去掉前面的注释分号就行了。

   但这时打开存取 Oracle 数据库的 PHP 页面,又会出现“ORA-12705”错误,即:

   ORA-12705: Cannot access NLS data files or invalid environment specified in ……

   解決办法:按以下路径打开注册表:
   HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE
   找到 NLS_LANG 键值 ,这个键值现在是 NA,因此將 NLS_LANG 的值改为 SIMPLIFIED CHINESE_CHINA.ZHS16GBK,和 Oracle 数据库服务器上的一致。

   再加三个环境变量的值

   TNS_ADMIN 等于 D:\instantclient_11_1
   NLS_LANG 等于 SIMPLIFIED CHINESE_CHINA.ZHS16GBK
   LD_LIBRARY_PATH 等于 D:\instantclient_11_1

   完成后,注册表中会自动记录在以下路径:

   [HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\session Manager\Environment]
   “LD_LIBRARY_PATH”=”D:\instantclient_11_1″
   “NLS_LANG”=”SIMPLIFIED CHINESE_CHINA.ZHS16GBK”
   “TNS_ADMIN”=”D:\instantclient_11_1″

   如果使用了 tnsnames.ora 文件定义 Oracle 网络服务名称(tnsnames.ora文件在数据库服务器的 [ORACLE_HOME]\network\admin文件夹下),则将 tnsnames.ora 复制到 D:\instantclient_11_1,并添加用户环境变量 TNS_ADMIN,设置为你的解压目录如 D:\instantclient_11_1。(也可以在用户环境变量 LOCAL 中定义默认的服务名称。)

   客户管理包里还有一些很有用的程序,如启动 sqlplus 为 sqlplus system/manager@localdb。Oracle ODBC 的安装可以运行 odbc_install 或者 odbc_install ZHS。

   这时用 phpinfo() 函数应该看到浏览器输出页面应包含一个显示“OCI8 Support enabled”的信息。这样就配置好了,写一段代码测试吧。

   作者:张庆(网眼) 2009-10-21

Tags:Windows PHP Apache

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接