时间:2021-07-01 10:21:17 帮助过:19人阅读
第一次的错误中文缓存的文件中是有中文的,不过编码是GB2312,删掉缓存文件,刷新后重新生成缓存,缓存文件的编码就变成utf-8了
刷新后的内容是否与之前一样,只是编码变了?
第一次的错误中文缓存的文件中是有中文的,不过编码是GB2312,删掉缓存文件,刷新后重新生成缓存,缓存文件的编码就变成utf-8了
刷新后的内容是否与之前一样,只是编码变了?
1、thinkphp 使用 utf-8 字符集工作,并无 gbk 版本
2、json_encode 只支持 utf-8 中文
因此无论是传入还是传出都应是 utf-8 的,所以你连接 oracle 时声明 ZHS16GBK 是错误的。这是问题的根源
1、thinkphp 使用 utf-8 字符集工作,并无 gbk 版本
2、json_encode 只支持 utf-8 中文
因此无论是传入还是传出都应是 utf-8 的,所以你连接 oracle 时声明 ZHS16GBK 是错误的。这是问题的根源
你在连接数据库时将 ZHS16GBK 改为 UTF-8 呢?试过没有
你在连接数据库时将 ZHS16GBK 改为 UTF-8 呢?试过没有
连接数据库就是用的utf8。在tp的config中配置数据库字符集就是utf8。。。如果设置成zhs16gbk,也是这个现象因为只是第一次连接数据库的时候返回的数据编码不对,再次操作的时候就都没问题了,无疑与oracle的什么机制有关,也不想去深究了,解决问题为上,我直接在所有类都继承的初始化类:common.action.class中加了一句$pre->M();$pre_list =$pre->query('select sysdate from dual');等于所有的数据操作开始之前先连接库查询一下时间,也不用返回,就是这么执行一下就行,相当于初始化连接,这个如果是返回的中文的话应该是编码异常的,不过我也不需要它返回,仅仅是初始化一下,然后再做其他操作时编码正常就ok了。感谢两位版主的回复,结贴给分,谢谢。。。
终于摸索出来了。直接在apache的fcgi配置中配上php的环境:FcgidInitialEnv NLS_LANG AMERICAN_AMERICA.UTF8,因为是fcgi连接,所以许多php的environment中的数据都是没有的,必须在fcgi配置中自己添加,原来我是添加的和win中配置一样的zhs16gbk,但是上次看oracle会根据客户端字符集自动转码,刚才试了下,果然出来的数据由oracle自动返回了utf8编码,这样就不需要通过初始化连接来实现了。。。以后有连接oracle的同学,同时php配的是fcgi方式的可以参考下