欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-16 09:27:00
...

  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