Chinaunix

标题: apache+perl提取oracle中文数据乱码 [打印本页]

作者: smonkey0    时间: 2008-05-28 17:28
标题: apache+perl提取oracle中文数据乱码
请大家帮帮忙啊。
首先说明一下情况:
数据库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设的有问题,还是别的啊。。。。
作者: freedom_L    时间: 2008-05-28 18:27
试过字符转换吗?导出后转换一下试试吧。
作者: smonkey0    时间: 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系统的编码吗?
作者: hmglly    时间: 2008-05-29 09:26
'AMERICAN_AMERICA.ZHS16GBK'和gb2312是不一样的
在web中指定了gb2312,可能是全局上仍然是gb2312的编码方式去数据库提取编码是'AMERICAN_AMERICA.ZHS16GBK'的字符串
oracle的编码方式可以改一下,应该不是这个'AMERICAN_AMERICA.ZHS16GBK'
作者: freedom_L    时间: 2008-05-29 15:26
你的WEB是Linux吧?你把你的测试平台与LINUX平台全统一成UTF-8试过吗?
作者: smonkey0    时间: 2008-05-30 14:04
原帖由 freedom_L 于 2008-5-29 15:26 发表
你的WEB是Linux吧?你把你的测试平台与LINUX平台全统一成UTF-8试过吗?

当初也考虑到linux可能语言问题会更麻烦,所以,就把APACHE和ORACLE都装在同一台机器上了。系统是2003
作者: smonkey0    时间: 2008-06-02 17:38
标题: 回复 #6 smonkey0 的帖子
自杀的心都有了。。我把字符试了个遍。把数据库都重装换成utf8 了。还是不行。。。。神啊。。收了我吧。。。
作者: smonkey0    时间: 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试试了。。。
作者: weiqk    时间: 2008-06-06 10:24
windows?
在我的电脑上右键
属性=》高级=》环境变量
作者: hmglly    时间: 2008-06-06 10:54
打开oracle的日志活动,用perl访问oracle看看日志中oracle接受的sql语句和用http访问oracle中的sql语句有什么不同
作者: smonkey0    时间: 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

结果依然没变。。。。怎么个回事儿吗。。。。。。
作者: hmglly    时间: 2008-06-06 15:12
你的apache的环境变量有了,你的程序的环境变量呢?是用的apache的吗?
作者: smonkey0    时间: 2008-06-06 16:08
标题: 回复 #12 hmglly 的帖子
嗯。。上面任何一种方法,在程序里加上 print $ENV{NLS_DATE_FORMAT};
都能打印出相应的环境变量,所以说程序的环境变量就成功导入了。
作者: hmglly    时间: 2008-06-06 17:47
从屏幕打印出环境变量和输送到数据库是两个过程,能在屏幕上打印出来,不代表输送到数据库的环境变量也是这样的
打开apache的debug,看看输送的是什么东西
作者: vyoung    时间: 2008-06-08 15:36
标题: 回复 #1 smonkey0 的帖子
把perl文件保存为GB2312字符编码格式试试~~




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2