首頁 >後端開發 >php教程 >php设置中文cookie,读取echo出来乱码,写进mysql又没有乱码,为什么?

php设置中文cookie,读取echo出来乱码,写进mysql又没有乱码,为什么?

WBOY
WBOY原創
2016-06-06 20:22:261243瀏覽

已经在所有页面设置header为utf-8。乱码导致没办法和数据里的数据就行比较,和原文不相等了。

回复内容:

已经在所有页面设置header为utf-8。乱码导致没办法和数据里的数据就行比较,和原文不相等了。

找到原因,因为写入数据库用函数mysql_real_escape()进行了处理,而取出没有进行反向处理导致中文乱码,使用stripslashes()进行处理后读出正常。

首先你你应该看下文件编码,如果文件编码是gbk,header也木用,header只是告诉客户端以下内容按照utf8解析,跟文件或者内容本身编码无关,至于数据库会不会乱码,这个跟字符集范围有关系,数据库会不会乱码可以举个例子:如果文件是gbk编码,数据库字段是utf8,存储的时候set names utf8,读取出来在utf8的文件中展示的时候设置charset是utf8,我的理解是不会乱码的,因为gbk的字符集范围比utf8小,gbk内容以utf8编码是可以存储下的,而以utf8存储再以utf8展示是不会乱码的,如果以gbk读出来我觉得是会乱码的,虽然文件是gbk,但是是以utf8存储在数据库的,而utf8是占三字节或以上,而gbk是两个字节,所以gbk展示不了utf8的内容,所以会乱码,纸上谈兵,没有实践过,在此谬论,我只是说我是这么理解的!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn