免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6609 | 回复: 14
打印 上一主题 下一主题

[Web] apache+perl提取oracle中文数据乱码 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-05-28 17:28 |只看该作者 |倒序浏览
10可用积分
请大家帮帮忙啊。
首先说明一下情况:
数据库oracle 10r2, 装在另一台机器上,系统为2003上,字附编码为:NLS_LANG='AMERICAN_AMERICA.ZHS16GBK';

apache测式服务器在我自己的机器上:系统为xp, apache版本2.2.4

遇到的问题是:如果我在本机写的perl代码,加上环境变量
$ENV{NLS_LANG} = 'AMERICAN_AMERICA.ZHS16GBK';
后从数据库里提取的中文数据能正常显示,
但是一旦把这段代码放到web页面中,提取的数据就变成乱码了。(注意,我确认过了,是提取出来的就是乱码,而不是显示时才乱码的)

我的页面字符编码是
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
另外: apache 的http.conf 已加上     AddDefaultCharset   GB2312   。

请有处理过此类情况的高手帮帮忙,是我的apache设的有问题,还是别的啊。。。。

论坛徽章:
0
2 [报告]
发表于 2008-05-28 18:27 |只看该作者
试过字符转换吗?导出后转换一下试试吧。

论坛徽章:
0
3 [报告]
发表于 2008-05-28 18:53 |只看该作者
原帖由 freedom_L 于 2008-5-28 18:27 发表
试过字符转换吗?导出后转换一下试试吧。

嗯,试过了,用utf8和GB2312都试过了,但还是不行。

这个问题有点很有意思。就是我的APACHE是架在我自己机器上的,但我直接写个角本在角本里设置环境变量NLS_LANG='SIMPLIFIED CHINESE_CHINA.ZHS16GBK'
在cmd窗口运行,数据提出来都是正常的,显示也正常,
但同样的脚本放在web上的时候,提出来的就是乱码,显示不用说还是乱码了。。

所以我觉得是APACHE的编码环境和我本机的SHELL编码环境的区别造成的。有办法让APACHE的环境变得和本机一样吗?
莫非 AddDefaultCharset   GB2312 这句话加的编码不对?windows环境不都是gbk系统的编码吗?

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-09-29 06:20:00
4 [报告]
发表于 2008-05-29 09:26 |只看该作者
'AMERICAN_AMERICA.ZHS16GBK'和gb2312是不一样的
在web中指定了gb2312,可能是全局上仍然是gb2312的编码方式去数据库提取编码是'AMERICAN_AMERICA.ZHS16GBK'的字符串
oracle的编码方式可以改一下,应该不是这个'AMERICAN_AMERICA.ZHS16GBK'

论坛徽章:
0
5 [报告]
发表于 2008-05-29 15:26 |只看该作者
你的WEB是Linux吧?你把你的测试平台与LINUX平台全统一成UTF-8试过吗?

论坛徽章:
0
6 [报告]
发表于 2008-05-30 14:04 |只看该作者
原帖由 freedom_L 于 2008-5-29 15:26 发表
你的WEB是Linux吧?你把你的测试平台与LINUX平台全统一成UTF-8试过吗?

当初也考虑到linux可能语言问题会更麻烦,所以,就把APACHE和ORACLE都装在同一台机器上了。系统是2003

论坛徽章:
0
7 [报告]
发表于 2008-06-02 17:38 |只看该作者

回复 #6 smonkey0 的帖子

自杀的心都有了。。我把字符试了个遍。把数据库都重装换成utf8 了。还是不行。。。。神啊。。收了我吧。。。

论坛徽章:
0
8 [报告]
发表于 2008-06-04 09:30 |只看该作者

回复 #7 smonkey0 的帖子

我找到原因了,但不知道怎么办了。
ORALCE 里有个关于时间的格式的环境变量:$ENV{NLS_DATE_FORMAT}   =   'YYYY-MM-DD'我不设的话,WEB上取出来是:29-MAY-08   英文的 'DD-MM-YY';
但就算我加了在代码里加上:$ENV{NLS_DATE_FORMAT}   =   'YYYY-MM-DD'取出来还是  英文的 'DD-MM-YY' ,  好像mod_perl(或者是APACHE) 没有把这个信息输到数据库服务器一样。
所以说这个程序最关键的环境变量
$ENV{NLS_LANG}='SIMPLIFIED CHINESE_CHINA.UTF8'
肯定是没有凑效了。。

我分别试过几种方法:
1.在代码里加上  $ENV{NLS_LANG}=。。。 之类的方法,--->失败
2.在HTTP.CONF 里加上 SetEnv NLS_LANG CHINESE_CHINA.UTF   SetEnv NLS_DATE_FORMAT YYYY-MM-DD  --->失败
3.在HTTP.CONF 里加上
PerlSetEnv NLS_LANG CHINESE_CHINA.UTF8
PerlSetEnv NLS_DATE_FORMAT YYYY-MM-DD
PerlPassEnv NLS_LANG
PerlPassEnv NLS_DATE_FORMAT
结果导致apache 运行出错。原因网上据说是apache2对mod_perl 的支持问题。。

现在好迷茫,如果实在不行,打算着再加个php试试了。。。

论坛徽章:
0
9 [报告]
发表于 2008-06-06 10:24 |只看该作者
windows?
在我的电脑上右键
属性=》高级=》环境变量

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-09-29 06:20:00
10 [报告]
发表于 2008-06-06 10:54 |只看该作者
打开oracle的日志活动,用perl访问oracle看看日志中oracle接受的sql语句和用http访问oracle中的sql语句有什么不同
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP