开发者社区> 问答> 正文

php网页与mysql的字符编码问题!

一般在php与mysql中,涉及到字符编码有四个位置

  1. html的meta标签中
    2..html或者.php文件的字符类型

3.mysql中的数据库的字符集
4.表中字段的字符编码。
那么为了防止在数据库中或者在前端中,中文显示出现乱码,
上面的字符编码应该怎样设置呢?

展开
收起
小旋风柴进 2016-03-09 11:40:04 2535 0
1 条回答
写回答
取消 提交回答
  • 建议数据库用utf8编码
    1.mysql数据库默认的编码是utf8,如果这种编码与你的PHP网页不一致,可能就会造成MYSQL乱码. 2.MYSQL中创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码. 3.MYSQL创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.
    4.用户提交页面的编码与显示数据的页面编码不一致,就肯定会造成PHP页面乱码.
    5.如用户输入资料的页面是big5码, 显示用户输入的页面却是gb2312,这种100%会造成PHP页面乱码. 6.PHP页面字符集不正确. 7.PHP连接MYSQL数据库语句指定的编码不正确. 使用mysql+php产生乱码的原因都了解得很清楚了,那么解决就不困难了.
    针对不同问题的解决方法: 1.mysql数据库默认的编码是utf8,如果这种编码与你的PHP网页不一致,可能就会造成MYSQL乱码. 修改数据库编码,如果是数据库编码不正确,可以在phpmyadmin 执行如下命令: ALTER DATABASE 'test' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin 以上命令就是将test数据库的编码设为utf8.
    2.MYSQL中创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码. 修改表的编码: ALTER TABLE 'category' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin 以上命令就是将一个表category的编码改为utf8.
    3.MYSQL创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码. 修改字段的编码: ALTER TABLE 'test' CHANGE 'dd' 'dd' VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL 以上命令就是将test表中 dd的字段编码改为utf8.
    4.用户提交页面的编码与显示数据的页面编码不一致,就肯定会造成PHP页面乱码. 如果是这种情况容易解决,只需检查下页面,修改源文件的charset即可.
    5.如用户输入资料的页面是big5码, 显示用户输入的页面却是gb2312,这种100%会造成PHP页面乱码. 这种情况也是修改页面charset即可.
    6.PHP页面字符集不正确. 为了避免PHP页面乱码的发生,PHP页面开始第一句 header("content-type:text/html; charset=utf-8"); //强行指定页面的编码,以避免乱码
    7.PHP连接MYSQL数据库语句指定的编码不正确. 在连接数据库的语句中. mysql_connect('localhost','user','password'); mysql_select_db('my_db'); mysql_query("set names utf8;"); //或写为 mysql_query("SET CHARACTER SET utf8");

    2019-07-17 18:55:42
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
阿里云栖开发者沙龙PHP技术专场-直面PHP微服务架构挑战-高驰涛 立即下载
PHP安全开发:从白帽角度做安全 立即下载
PHP 2017.北京 全球开发者大会——高可用的PHP 立即下载

相关镜像