数据库数据在浏览器显示乱码(同浏览器,同数据源,同utf8,不同服务器)

WBOY
发布: 2016-06-06 20:14:46
原创
1372 人浏览过

同一个mysql数据源,同一个浏览器,访问线上测试无乱码,localhost访问就有乱码,我想这是不是服务器环境的问题?

补充:中文在mysql中显示是正常的。
补充:本地和测试服务器php.ini中default_charset都是注释掉的。
补充:my bad, 我习惯的认为应该不是mysql设置字符编码的问题(基于代码都是一样的),当我试着指定字符编码时,问题得以解决。常理说来,编码问题无非三个地方,php,mysql,浏览器设置,都统一问题一般都没有了。

回复内容:

同一个mysql数据源,同一个浏览器,访问线上测试无乱码,localhost访问就有乱码,我想这是不是服务器环境的问题?

补充:中文在mysql中显示是正常的。
补充:本地和测试服务器php.ini中default_charset都是注释掉的。
补充:my bad, 我习惯的认为应该不是mysql设置字符编码的问题(基于代码都是一样的),当我试着指定字符编码时,问题得以解决。常理说来,编码问题无非三个地方,php,mysql,浏览器设置,都统一问题一般都没有了。

按照你的说法,既然数据库是同一个,浏览器也是同一个,代码也肯定是同一个了,那么基本上问题出在php上,
1.查看你的php配置的默认编码是否是utf-8,最好拿phpinfo()看一下

<code>default_charset = "utf-8";</code>
登录后复制

2.查看你的数据库连接抽象层,在php与MySQL交互的地方,是否设定了编码规则,如果你用的是mysqli,最起码要这样设定一下

<code>$mysqli->set_charset("utf8")</code>
登录后复制

1、HTML 文档的 head 指定了与后端处理程序指定的一致的编码了没有呢?
2、查看一下数据库里的表或字段使用的编码,是否与后端程序的编码一致(不一致的话,比如 UTF-8 强行转 GBK 可能导致乱码)。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板