关于数据上传到php服务器乱码的问题

数据上传到服务器会产生乱码(一般都是中文乱码)

原因:

你的数据采用的编码方式和php服务器的编码方式不一致导致的,主要编码方式有UTF-8、gb2312、GBK,UTF-8、gb2312、GBK他们都是一种编码方式。

GBK编码:是指中国的中文字符,其它它包含了简体中文与繁体中文字符。

gb2312编码:仅能存储简体中文字符。

UTF-8编码:它是一种全国家通过的一种编码,如果网站涉及到多个国家的语言,那么建议选择UTF-8编码。一般推荐使用UTF-8编码方式。

解决方案:

method1:

最简单暴力的,如果不想修改文件,可以直接查找服务器配置,将其修改为与你文件相同的编码方式,我之前使用出错就是因为我的编码方式是使用UTF-8编码,php服务器采用gb2312编码,所以善生乱码,将服务器的配置更改为UTF-8编码,一切就搞定了。

但是服务器配置文件很多,有时候修改错了的话就无法运行了,所以不建议使用此方法。

method2:

不修改服务器,仅在php文件中加上这句话,并且这句话必须放在数据库服务器连接语句

// 创建连接
$conn = new mysqli($servername, $username, $password,$dbname);

// 检测连接
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

之后

$conn->query("SET NAMES 'UTF8'");

也可以解决乱码问题。

原理:

先说MySQL的字符集问题。Windows下可通过修改my.ini内的

PHP代码
[mysql]  
 default-character-set=utf8    //客户端的默认字符集
 [mysqld]
default-character-set=utf8    //服务器端默认的字符集
假设我们把两个都设为utf8,然后在MySQL Command Line Client里面输入“show variebles like“character_set_%”;”,可看到如下字符:
character_set_client   latin1
character_set_connection    latin1
character_set_database     utf8
character_set_results    latin1
character_set_server   utf8
character_set_system     utf8
要是我们通过采用UTF-8的PHP程序从数据库里读取数据,很有可能是一串“?????”或者是其他乱码。

解决办法是,在连接数据库之后,读取数据之前,先执行一项查询“SET NAMES UTF8”,

到MySQL命令行输入“SET NAMES UTF8;”,然后执行“show variebles like“character_set_%”;”,发现原来为latin1的那些变量“character_set_client”、“character_set_connection”、“character_set_results”的值全部变为utf8了,原来是这3个变量的原因。

查阅手册,上面那句等于:

SET character_set_client = utf8;       
SET character_set_results = utf8;      
SET character_set_connection = utf8;  

看看这3个变量的作用:
信息输入路径:client→connection→server;
信息输出路径:server→connection→results。
换句话说,每个路径要经过3次改变字符集编码。以出现乱码的输出为例,server里utf8的数据,传入connection转为latin1,传入results转为latin1,utf-8页面又把results转过来。如果两种字符集不兼容,比如latin1和utf8,转化过程就为不可逆的,破坏性的。

但这里要声明一点,“SET NAMES UTF8”作用只是临时的,MySQL重启后就恢复默认了。

你可能感兴趣的:(php)