如何解决php甲骨文乱码的问题

  介绍

如何解决php甲骨文乱码的问题?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

php甲骨文乱码的解决办法:首先通过PLSQL运行“select * from V $ NLS_PARAMETERS;”获取甲骨文的字符集,然后在客户端正确的设置服务端的字符集信息即可。

<强> php甲骨文中文乱码问题

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

设置字符集的方法如下:

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

putenv (“NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1");   (康涅狄格州=oci_new_connect美元配置[& # 39;用户名# 39;],美元配置[& # 39;密码# 39;],美元配置[& # 39;数据库# 39;]);

相关介绍:

甲骨文一般指甲骨文公司;

甲骨文公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩.1989年正式进入中国市场.2013年,甲骨文已超越IBM,成为继微软后全球第二大软件公司。

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

$康涅狄格州=oci_new_connect(美元配置[& # 39;用户名# 39;],美元配置[& # 39;密码# 39;],美元配置[& # 39;数据库# 39;],& # 39;we8iso8859p1& # 39;);

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

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

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

回声iconv (& # 39; gbk # 39; & # 39; utf - 8 # 39;,签证官美元[“USERNAME"]);

看完上述内容,你们掌握如何解决php甲骨文乱码的问题的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注行业资讯频道,感谢各位的阅读!

如何解决php甲骨文乱码的问题