[原创]PHP中文保存到mySQL乱码问题

最近又转PHP了,做了个简单的CRUD例子,发现存储到MySQL中的中文变成了“???”,于是百度了下,发现有如下问题的还很多

大多原因是因为没有设置mySQL的字符设置的问题

  1. PHP+MySQL出现中文乱码的原因。

    1. MYSQL数据库的编码是utf8,与PHP网页的编码格式不一致,就会造成MYSQL中的中文乱码。

    2. 使用MYSQL中创建表、或者选择字段时设置的类型不是utf8,而网页编码不是utf8,也可能造成MYSQL中文乱码.

    3. PHP页面的字符集与数据库的编码不一致。

    4. PHP连接MYSQL数据库,操作是设定的语句指定的编码和页面编码,PHP页面编码不一致。

    5. 用户提交的HTML页面编码,和显示数据的页面编码不一致 ,就肯定会造成PHP页面乱码.

  2. 怎么解决中文乱码的问题。

    1. 网页编码设置。一般在HTML代码中的文件头<html>中加入属性:

    <meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″>

    保证,网页是”utf-8″编码。

    2. PHP代码设置。在php代码的开始部分加入以下代码:

    header(”Content-type: text/html;charset=utf-8″);

    且要求保存的文件编码方式是utf-8(可以用EditPlus打开设置,如下图),这样就保证了该文件也是utf-8编码。

    3. 数据库中表的字段中存储中文的部分,要设置为utf8_general_ci类型。

    4.PHP在连接数据库操作时,要设置操作的字段类型为utf8,设置方法如下:

    mysql_connect(’localhost’,’user’,’password’);mysql_select_db(’db’);mysql_query(”set names utf8;”); //**设置字符集***

  3. 实例对比。通过上面的分析,我们按照解决方案,得到了正确的中文编码存储在MySQL中,效果如下图所示:

 

赞(0) 打赏
分享到: 更多 (0)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏