免费注册 查看新帖 |

Chinaunix

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

[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: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系统的编码吗?

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

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

论坛徽章:
0
4 [报告]
发表于 2008-06-02 17:38 |显示全部楼层

回复 #6 smonkey0 的帖子

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

论坛徽章:
0
5 [报告]
发表于 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
6 [报告]
发表于 2008-06-06 15:08 |显示全部楼层
原帖由 hmglly 于 2008-6-6 10:54 发表
打开oracle的日志活动,用perl访问oracle看看日志中oracle接受的sql语句和用http访问oracle中的sql语句有什么不同

现在通过以下方法测式,知道问题发生在哪了,但是仍不知道如何解决。
将环境变量
NLS_LANG   =>  'AMERICAN_AMERICA.ZHS16GBK';
NLS_DATE_FORMAT   =>   'YYYY-MM-DD';

分别以下面三种方法添加,并在DOS下和WEB下分别运行   select * from nls_session_parameters;
1. 添加环境变量
2. 添加注册表相应的项
3. 在程序中设定临时环境变量:(perl)
$ENV{NLS_LANG}='AMERICAN_AMERICA.ZHS16GBK';
$ENV{NLS_DATE_FORMAT}   =   'YYYY-MM-DD';
a.DOS下显示:
NLS_LANGUAGE = AMERICAN
NLS_TERRITORY = AMERICA
NLS_CURRENCY = $
NLS_ISO_CURRENCY = AMERICA
NLS_NUMERIC_CHARACTERS = .,
NLS_CALENDAR = GREGORIAN
NLS_DATE_FORMAT = YYYY-MM-DD
NLS_DATE_LANGUAGE = AMERICAN
NLS_SORT = BINARY
NLS_TIME_FORMAT = HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT = DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT = HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT = DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY = $
NLS_COMP = BINARY
NLS_LENGTH_SEMANTICS = BYTE
NLS_NCHAR_CONV_EXCP = FALSE
b.WEB下显示:
NLS_LANGUAGE = AMERICAN
NLS_TERRITORY = AMERICA
NLS_CURRENCY = $
NLS_ISO_CURRENCY = AMERICA
NLS_NUMERIC_CHARACTERS = .,
NLS_CALENDAR = GREGORIAN
NLS_DATE_FORMAT = DD-MON-RR
NLS_DATE_LANGUAGE = AMERICAN
NLS_SORT = BINARY
NLS_TIME_FORMAT = HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT = DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT = HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT = DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY = $
NLS_COMP = BINARY
NLS_LENGTH_SEMANTICS = BYTE
NLS_NCHAR_CONV_EXCP = FALSE


发现一个问题了吧? 就是在WEB中的环境变量压根儿就没传过去。后来又试了下将http.conf里添加
SetEnv NLS_LANG AMERICAN_AMERICA.ZHS16GBK
SetEnv NLS_DATE_FORMAT YYYY-MM-DD

结果依然没变。。。。怎么个回事儿吗。。。。。。

论坛徽章:
0
7 [报告]
发表于 2008-06-06 16:08 |显示全部楼层

回复 #12 hmglly 的帖子

嗯。。上面任何一种方法,在程序里加上 print $ENV{NLS_DATE_FORMAT};
都能打印出相应的环境变量,所以说程序的环境变量就成功导入了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP