PHP8.1.21版本已发布
vue8.1.21版本已发布
jquery8.1.21版本已发布

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

原创
2016-06-06 20:22:26 900浏览

已经在所有页面设置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核实处理。