>  기사  >  백엔드 개발  >  数据库数据在浏览器显示乱码(同浏览器,同数据源,同utf8,不同服务器)

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

WBOY
WBOY원래의
2016-06-06 20:14:461330검색

同一个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 可能导致乱码)。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.