十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章将为大家详细讲解有关php向数据库插入数据出现乱码问题怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
网站建设、成都网站建设的关注点不是能为您做些什么网站,而是怎么做网站,有没有做好网站,给成都创新互联一个展示的机会来证明自己,这并不会花费您太多时间,或许会给您带来新的灵感和惊喜。面向用户友好,注重用户体验,一切以用户为中心。php向数据库插入数据出现乱码的解决办法:首先将数据库的编码设为utf8;然后判断要插入数据库的文本编码方式;最后通过switch语句实现数据判断插入即可。
php向数据库插入数据出现乱码问题
一般插入到数据库的数据乱码都是编码的问题,可以在插入数据库前查看下内容的编码方式,如果和数据库用的编码方式(如:utf-8)一样就执行插入操作,不一样就进行转码。
先判断你要插入数据库的文本的编码方式,是utf-8就插入,不是的话要转为utf-8之后再插入:
$e=mb_detect_encoding($text, array('UTF-8', 'GBK', 'gb2312')); switch($e){ case 'UTF-8' : //如果是utf8编码就直接插入数据库 break; case 'GBK': //如果是gbk编码就转换为utf-8之后再插入数据库 iconv("GBK", "UTF-8",$data) ; break; case 'GB2312': //如果是GB2312编码就转换为utf-8之后再插入数据库 iconv("GB2312", "UTF-8",$data) ; break; }
本以为程序中的编码和数据库用的编码保持一致就不会出现乱码了,可是,插入数据库的数据还是有乱码出现,排除了编码不一致之后,就想到可能是使用php连接mysql时没有设定mysql编码的缘故,果然,在连接数据库之后将数据库的编码也设为utf8之后再进行数据库插入操作就没有乱码了。
代码如下:
$this->conn = mysqli_connect($db['default']['hostname'], $db['default']['username'], $db['default']['password'], $db['default']['dbname']) or die('Connect error!'); //连接到数据库 mysqli_set_charset($this->conn, 'utf8'); //此处不能用utf-8
关于php向数据库插入数据出现乱码问题怎么办就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。