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 相关文章推荐
PHP批量生成缩略图的代码
Jul 19 PHP
openPNE常用方法分享
Nov 29 PHP
PHP定时任务延缓执行的实现
Oct 08 PHP
php面向对象与面向过程两种方法给图片添加文字水印
Aug 26 PHP
PHP附件下载中文名称乱码的解决方法
Dec 17 PHP
Zend Framework教程之路由功能Zend_Controller_Router详解
Mar 07 PHP
php mongodb操作类 带几个简单的例子
Aug 25 PHP
thinkPHP多语言切换设置方法详解
Nov 11 PHP
php生出随机字符串
Jul 06 PHP
PHP 应用容器化以及部署方法
Feb 12 PHP
Yaf框架封装的MySQL数据库操作示例
Mar 06 PHP
PHP实现简单的协程任务调度demo示例
Feb 01 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
40年前的这部特摄片恐龙特级克塞号80后的共同回忆
2020/03/08 日漫
ThinkPHP模板比较标签用法详解
2014/06/30 PHP
php生成Android客户端扫描可登录的二维码
2016/05/13 PHP
ThinkPHP简单使用memcache缓存的方法
2016/11/15 PHP
深入学习微信网址链接解封的防封原理visit_type
2019/08/15 PHP
重载toString实现JS HashMap分析
2011/03/13 Javascript
php常见的页面跳转方法汇总
2015/04/15 Javascript
由ReactJS的Hello world说开来
2015/07/02 Javascript
Vue.js 2.0 和 React、Augular等其他前端框架大比拼
2016/10/08 Javascript
jQuery实现获取隐藏div高度的方法示例
2017/02/09 Javascript
微信小程序云开发 搭建一个管理小程序
2019/05/17 Javascript
uni app仿微信顶部导航条功能
2019/09/17 Javascript
浅谈Vue组件单元测试究竟测试什么
2020/02/05 Javascript
Python类的基础入门知识
2008/11/24 Python
python mysqldb连接数据库
2009/03/16 Python
python虚拟环境virtualenv的使用教程
2017/10/20 Python
Numpy数组的保存与读取方法
2018/04/04 Python
对PyQt5的输入对话框使用(QInputDialog)详解
2019/06/25 Python
python实现凯撒密码、凯撒加解密算法
2020/06/11 Python
Python通用唯一标识符uuid模块使用案例
2020/09/10 Python
python switch 实现多分支选择功能
2020/12/21 Python
is_file和file_exists效率比较
2021/03/14 PHP
香港太阳眼镜网上商店:SmartBuyGlasses香港
2016/07/22 全球购物
美国高品质个性化珠宝销售网站:Jewlr
2018/05/03 全球购物
奥地利体育网上商店:Gigasport
2019/10/09 全球购物
JBL美国官方商店:扬声器、耳机等
2019/12/01 全球购物
厨师岗位职责
2013/11/12 职场文书
自动化专业个人求职信范文
2013/11/29 职场文书
导师评语大全
2014/04/26 职场文书
村抢险救灾方案
2014/05/09 职场文书
纪念九一八事变演讲稿:青少年应树立远大理想
2014/09/14 职场文书
2015秋季开学典礼演讲稿
2015/07/16 职场文书
总经理年会致辞
2015/07/29 职场文书
交通安全主题班会
2015/08/12 职场文书
nginx对http请求处理的各个阶段详析
2021/03/31 Servers
Vue如何清空对象
2022/03/03 Vue.js