PHP和Mysql中转UTF8编码问题汇总


Posted in PHP onOctober 10, 2015

一个网站如果需要国际化,就需要将编码从GB2312转成UTF-8,其中有很多的问题需要注意,如果没有转换彻底,将会有很多的编码问题出现!
PHP页面转UTF-8编码问题
1.在代码开始出加入一行: header("Content-Type: text/html;charset=utf-8");
2.PHP文件编码问题 点击编辑器的菜单:“文件”->“另存为”,可以看到当前文件的编码,确保文件编码为:UTF-8,如果是ANSI,需要将编码改成:UTF-8。
3.PHP文件头BOM问题: PHP文件一定不可以有BOM标签,否则,会出现session不能使用的情况,并有类似的提示: Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent 这是因为,在执行session_start() 的时候,整个页面不能有输出,但是当由于前PHP页面存在BOM标签,PHP把这个BOM标签当成是输出了,所以就出错了! 所以PHP页面一定要删除BOM标签
删除这个BOM标签的方法:
1.可以用Dreamweaver打开文件,并重新保存,即可以去除BOM标签!
2.可以用EditPlus打开文件,
并在菜单“首选项”->“文件”->"UTF-8标识",设置为:“总是删除签名”,然后保存文件,即可以去除BOM标签!
3.PHP以附件形式保存文件的时候,UTF-8编码问题: PHP以附件形式保存文件,文件名必须是GB2312编码,否则,如果文件名中有中文的话,将是显示乱码: 如果你的PHP本身是UTF-8编码格式的文件,需要将文件名变量由UTF-8转成GB2312: iconv("UTF-8", "GB2312", "$filename");
4.截断显示文章标题时,出现乱码或者“?”问号的问题:
一般文章标题很长的时候,会显示一部分标题,会对文章标题进行截断,由于一个UTF-8编码格式的中文字符会占用3个字符宽度,截取标题的时候,有时会只截取到一个中文字符的1个字符或2字符宽度,没截取完整,将出现乱码或“?”问号的情况,用下面的函数截取标题,就不会有问题:

function get_brief_str($str, $max_length) { 
  echo strlen($str) . ""; 
  if (strlen($str) > $max_length) { 
    $check_num = 0; 
    for ($i = 0; $i < $max_length; $i++) { 
      if (ord($str[$i]) > 128) 
        $check_num++; 
    } 
 
    if ($check_num % 3 == 0) 
      $str = substr($str, 0, $max_length) . "..."; 
    else 
      if ($check_num % 3 == 1) 
        $str = substr($str, 0, $max_length +2) . "..."; 
      else 
        if ($check_num % 3 == 2) 
          $str = substr($str, 0, $max_length +1) . "..."; 
  } 
 
  return $str; 
}

MYSQL数据库使用UTF-8编码的问题
1.用phpmyadmin创建数据库和数据表 创建数据库的时候,请将“整理”设置为:“utf8_general_ci”或执行语句:

CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

创建数据表的时候:如果是该字段是存放中文的话,则需要将“整理”设置为:“utf8_general_ci”,如果该字段是存放英文或数字的话,默认就可以了。
相应的SQL语句,例如:

CREATE TABLE `test` ( 
`id` INT NOT NULL , 
`name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , 
PRIMARY KEY ( `id` ) 
) ENGINE = MYISAM ;

2.用PHP读写数据库
在连接数据库之后:

$connection = mysql_connect($host_name, $host_user, $host_pass);

加入两行:

mysql_query("set character set 'utf8'");//读库 
mysql_query("set names 'utf8'");//写库

希望本文所述对大家的PHP+MySQL程序设计有所帮助。

PHP 相关文章推荐
Windows下的PHP5.0安装配制详解
Sep 05 PHP
php中global和$GLOBALS[]的分析之一
Feb 02 PHP
php FLEA中二叉树数组的遍历输出
Sep 26 PHP
php连接mssql数据库的几种方法
Feb 21 PHP
析构函数与php的垃圾回收机制详解
Oct 28 PHP
ThinkPHP3.1新特性之对分组支持的改进与完善概述
Jun 19 PHP
PHP的switch判断语句的“高级”用法详解
Oct 01 PHP
推荐5款跨平台的PHP编辑器
Dec 25 PHP
php结合md5实现的加密解密方法
Jan 25 PHP
Zend Framework创建自己的动作助手详解
Mar 05 PHP
PHP计算近1年的所有月份
Mar 13 PHP
PHP程序员简单的开展服务治理架构操作详解(二)
May 14 PHP
[原创]ThinkPHP中SHOW_RUN_TIME不能正常显示运行时间的解决方法
Oct 10 #PHP
PHP内存使用情况如何获取
Oct 10 #PHP
PHP中Session和Cookie是如何操作的
Oct 10 #PHP
PHP中JSON的应用技巧
Oct 10 #PHP
PHP的serialize序列化数据以及JSON格式化数据分析
Oct 10 #PHP
解决PHP里大量数据循环时内存耗尽的方法
Oct 10 #PHP
php中删除、清空session的方式总结
Oct 09 #PHP
You might like
PHP动态图像的创建
2006/10/09 PHP
PHP MySQL应用中使用XOR运算加密算法分享
2011/08/28 PHP
PHP中mysqli_affected_rows作用行数返回值分析
2014/12/26 PHP
带你了解PHP7 性能翻倍的关键
2015/11/19 PHP
php curl 模拟登录并获取数据实例详解
2016/12/22 PHP
比较详细的javascript对象的property和prototype是什么一种关系
2007/08/06 Javascript
纯JavaScript实现HTML5 Canvas六种特效滤镜示例
2013/06/28 Javascript
JS 实现导航栏悬停效果(续)
2013/09/24 Javascript
详解AngularJS中的表格使用
2015/06/16 Javascript
jQuery实现本地预览上传图片功能
2016/01/08 Javascript
使用jQuery Rotare实现微信大转盘抽奖功能
2016/06/20 Javascript
jQuery给div,Span, a ,button, radio 赋值与取值
2016/06/24 Javascript
BootStrap实现手机端轮播图左右滑动事件
2016/10/13 Javascript
基于bootstrap的选择框插件icheck
2016/12/23 Javascript
js实现做通讯录的索引滑动显示效果和滑动显示锚点效果
2017/02/18 Javascript
JS简单验证上传文件类型的方法
2017/04/17 Javascript
Vuex利用state保存新闻数据实例
2017/06/28 Javascript
详解如何将 Vue-cli 改造成支持多页面的 history 模式
2017/11/20 Javascript
Vue常见面试题整理【值得收藏】
2018/09/20 Javascript
[01:23]一分钟告诉你 DOTA2为什么叫信仰2
2014/06/20 DOTA
[46:03]LGD vs VGJ.T 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python的gevent框架的入门教程
2015/04/29 Python
Python 多进程和数据传递的理解
2017/10/09 Python
利用python实现周期财务统计可视化
2019/08/25 Python
Python任务调度模块APScheduler使用
2020/04/15 Python
CSS3教程(3):border-color网页边框色彩
2009/04/02 HTML / CSS
使用html5实现表格实现标题合并的实例代码
2019/05/13 HTML / CSS
Fox Racing官方网站:越野摩托车和山地自行车装备和服装
2019/12/23 全球购物
eDreams德国:南欧领先的在线旅游公司
2020/12/07 全球购物
PHP面试题-$message和$$message的区别
2015/12/08 面试题
艺术学院毕业生求职信
2014/07/09 职场文书
党的群众路线对照检查材料思想汇报(学校)
2014/10/04 职场文书
现实表现材料范文
2014/12/23 职场文书
话题作文之自信作文
2019/11/15 职场文书
什么是Python装饰器?如何定义和使用?
2022/04/11 Python
Win2008系统搭建DHCP服务器
2022/06/25 Servers