如何解决php 连接oracle乱码问题

本文操作环境:windows7系统、PHP7.1版、DELL G3电脑

如何解决php 连接oracle乱码问题?

PHP 连接Oracle及乱码问题笔记

1. PHP连接Oracle

步骤1. 提取oracle Instant Client核心DLL

从OTN 的 Instant Client 页面下载用于 Windows 的 Instant Client Basic(11g) 程序包。此压缩文件的大小大约为 48MB。创建一个子目录(例如,c:\instantclient11_2),然后从压缩文件中复制以下库到apache\bin目录下:

oraociei11.dll 
orannzsbb11.dll 
oci.dll

这三个文件的总大小大约为 126MB。
要使用 php 老版本的“oracle”扩展(在 php.ini 中使用“extension=php_oracle.dll”启用),则复制 ociw32.dll 而非 oci.dll。

步骤2:编辑环境变量,将 c:\instantclient11_2 添加到 PATH 中(系统环境变量位于其他 Oracle 目录之前)。

例如,在 Win7 上,依次单击“计算机”->右键“属性”->“高级系统设置”->“高级”->“环境变量”,编辑系统变量列表中的 PATH。
如果使用了 tnsnames.ora 文件定义 Oracle Net 服务名称,则将 tnsnames.ora 复制到 c:\instantclient11_2,并将用户环境变量 TNS_ADMIN 设置为 c:\instantclient11_2。

步骤3:打开php的oci8扩展 编辑 php.ini,把 OCI8 扩展打开,即去掉注释符号‘;’:extension=php_oci8.dll

重新启动 Apache。重启服务器(服务器必须重启,不然环境变量不起效)

重启后通过phpinfo() 看到以下内容则表示配置成功:

oci8

OCI8 Supportenabled
Version1.4.7
Revision$Id: bf2eaf558b050b6d2e6d098bed6345af7e842ea4 $
Active Persistent Connections0
Active Connections0
Oracle Run-time Client Library Version11.2.0.3.0
Oracle Instant Client Version11.2
Temporary Lob supportenabled
Collections supportenabled
DirectiveLocal ValueMaster Value
oci8.connection_classno valueno value
oci8.default_prefetch100100
oci8.eventsOffOff
oci8.max_persistent-1-1
oci8.old_oci_close_semanticsOffOff
oci8.persistent_timeout-1-1
oci8.ping_interval6060
oci8.privileged_connectOffOff
oci8.statement_cache_size2020

2. PHP Oracle 中文乱码问题

通常缺省配置连接Oracle在处理中文时都会遇到乱码问题,其实绝大部分人都知道在客户端连接Oracle服务端前首先要在客户端正确的设置服务端的字符集信息,通过PLsql运行“select * from V$NLS_PARAMETERS;” 即可获取oracle的字符集,变量NLS_CHARACTERSET对应的就是我们需要的字符集,比如我这里就是“WE8ISO8859P1”

设置字符集的方法如下:

方法一: 连接前设置环境变量

putenv("NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1");
$conn=oci_new_connect($config['username'], $config['passWord'],$config['database']);

方法二:连接时设置环境变量

 $conn=oci_new_connect($config['username'], $config['password'],$config['database'],'we8iso8859p1');

但是很快你会发现通过上述设置读取的中文数据在不设置编码的情况下可以正常显示,而一旦在页面(假如页面的字符集为UTF8)中使用则仍为乱码,

并且即便做转换 从 we8iso8859p1 -> utf-8 依旧为乱码。

其实仔细研究后发现oci8 以数据库编码WE8ISO8859P1获取数据后 自动转换为操作系统缺省的编码格式,假如我使用的操作系统缺省编码为GBK,则实际上通过OCI8读取后,字符的编码即为GBK, 因此在页面使用的时候编码转换应该为 从 GBK -> utf-8 :

 echo iconv('GBK','utf-8',$vo["USERNAME"]);

--结束END--

本文标题: 如何解决php 连接oracle乱码问题

本文链接: https://www.lsjlt.com/news/416.html (转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢

  • 如何解决php readdir 乱码问题

    php readdir乱码的解决办法:1、通过“mb_convert_encoding”修改编码;2、使用“utf8_encode”方法修改编码。
    阅读数:578 php readdir
  • 如何解决php imagecreate乱码问题

    php imagecreate乱码的解决办法:1、通过imagecreate创建画布;2、使用imagecolorallocate设置画布的背景颜色;3、设置“header('content-type:image/gif');”即可。
    阅读数:423 php imagecreate
  • 如何解决hbuild php乱码问题

    hbuild php乱码的解决办法:1、打开HBuilder软件;2、依次选择“文件”->“其他编码格式打开”->“utf-8;3、将文本文件编码的其他改成utf-8即可。
    阅读数:516 hbuild
  • 如何解决php exec乱码问题

    php exec乱码的解决办法:1、执行“exec("python cmd.py",$str);”;2、通过“iconv("GBK", "UTF-8", $res);”方式转换编码即可。
    阅读数:809 php exec
  • 如何解决php fpm出错问题

    php fpm出错的解决办法:1、在nginx的目录中创建个php的检测脚本index.php;2、找到nginx加载php配置的部分;3、修改路径即可。
    阅读数:168 php fpm
  • 如何解决php opendir乱码问题

    php opendir乱码的解决办法:1、打开相应的PHP代码文件;2、在输出前执行“$value=iconv("UTF-8","gb2312",$value);”语句;3、将所有文件编码都统一为UTF-8或gb2312即可。
    阅读数:535 php opendir
  • 如何解决php 535错误问题

    php 535错误的解决办法:1、删除项目data文件夹内的runtime文件夹;2、在浏览器界面按“ctrl+F”清除浏览器缓存即可。
    阅读数:240 php 535
  • 如何解决php exec报错问题

    php exec报错的解决办法:1、修改ping或者对应命令的执行权限;2、将命令全路径补全“exec('/usr/sbin',$output);”;3、在环境变量中增加目标目录。
    阅读数:323 php linux exec
  • 如何解决php header 失效问题

    php header失效的解决办法:1、取消location和“:”符号之间的空格;2、在用header前不能有任何的输出;3、修改php.ini打开缓存,并将“output_buffering=0”修改成409。
    阅读数:510 php header 失效
  • 如何解决php mail错误问题

    php mail错误的解决办法:1、在smtp服务的中继选项中添加本机IP地址;2、在网关做个端口映射,把25端口映射到本机即可。
    阅读数:879 php
  • 如何解决php 请求丢失问题

    php请求丢失的解决办法:1、给加密字串做urlencode处理再做发送;2、在curl中设置代理到fiddler的8888端口即可。
    阅读数:248 php
  • php glob 乱码问题如何解决

    php glob乱码的解决方法:1、检查并修改web服务器字符集和页面字符集;2、修改配置文件内容为“AddDefaultCharset UTF-8”。
    阅读数:906 php glob glob
  • 如何解决php 长度不足问题

    php长度不足的解决办法:1、创建一个PHP示例文件;2、通过“str_pad($value,2,0,STR_PAD_LEFT);”方式实现字符串固定长度不够补充其他字符串即可。
    阅读数:181 php 长度
  • 如何解决php admin乱码问题

    php admin乱码的解决办法:1、查看数据库编码;2、打开“my.ini”文件并找到“[client]”部分;3、添加语句“default-character-set=utf8”即可。
    阅读数:392 php admin
  • 如何解决php 微信输出乱码

    php微信输出乱码的解决办法:1、使用urlencode进行编码;2、通过“urldecode(json_encode($message));”方式转换编码即可。
    阅读数:209 php 乱码
  • 如何解决php 40001报错问题

    出现php 40001报错是因为access_token过期或不是最新的,导致发送模板消息报错,其解决办法就是重新修改access_token即可。
    阅读数:253 php
  • 如何解决php get 乱码问题

    php get乱码的解决办法:1、使用iconv函数将字符串按要求的字符编码进行转换;2、使用mb_convert_encoding转换编码即可。
    阅读数:224 php get
  • 如何解决php500错误问题

    php 500错误的解决办法:1、检查PHP脚本并修改;2、捕获异常并记录异常到日志;3、分析日志并处理即可。
    阅读数:204 php 500错误
  • 如何解决php define 报错问题

    php define报错是因为通过定义ture来使常量不区分大小写的做法是错的,其解决办法是弃用true作为define()的第三个参数。
    阅读数:771 php define
  • 如何解决php 签名出错问题

    php签名出错是因为嵌入到文档中的签名容器超出了原来为它预留的大小,其解决方法就是为签名容器预留更多空间即可。
    阅读数:1012 php 签名