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 相关文章推荐
mysql 查询指定日期时间内sql语句实现原理与代码
Dec 16 PHP
『PHP』PHP截断函数mb_substr()使用介绍
Apr 22 PHP
解析php dirname()与__FILE__常量的应用
Jun 24 PHP
PHP加密解密字符串汇总
Apr 26 PHP
php使用cookie实现记住登录状态
Apr 27 PHP
PHP实现的迷你漂流瓶
Jul 29 PHP
php基础设计模式大全(注册树模式、工厂模式、单列模式)
Aug 31 PHP
关于PHP 如何用 curl 读取 HTTP chunked 数据
Feb 26 PHP
PHP QRCODE生成彩色二维码的方法
May 19 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
Aug 29 PHP
php 使用ActiveMQ发送消息,与处理消息操作示例
Feb 23 PHP
Laravel配合jwt使用的方法实例
Oct 25 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与SQL注入攻击[一]
2007/04/17 PHP
php实例分享之二维数组排序
2014/05/15 PHP
今天你说520了吗?不仅有php表白书还有java表白神器
2016/05/20 PHP
PHP使用redis消息队列发布微博的方法示例
2017/06/22 PHP
thinkphp框架page类与bootstrap分页(美化)
2017/06/25 PHP
php+websocket 实现的聊天室功能详解
2020/05/27 PHP
JS 实现导航栏悬停效果
2013/09/23 Javascript
JS画线(实例代码)
2013/11/20 Javascript
javascript内置对象操作详解
2015/02/04 Javascript
不得不分享的JavaScript常用方法函数集(上)
2015/12/23 Javascript
jquery二级目录选中当前页的css样式
2016/12/08 Javascript
js制作可以延时消失的菜单
2017/01/13 Javascript
xmlplus组件设计系列之路由(ViewStack)(7)
2017/05/02 Javascript
原生JS实现的双色球功能示例
2018/02/02 Javascript
Vue CLI 3.x 自动部署项目至服务器的方法
2019/04/02 Javascript
vue改变对象或数组时的刷新机制的方法总结
2019/04/24 Javascript
js核心基础之闭包的应用实例分析
2019/05/11 Javascript
小程序多图列表实现性能优化的方法步骤
2019/05/28 Javascript
一文快速了解JQuery中的AJAX
2019/05/31 jQuery
微信小程序 网络通信实现详解
2019/07/23 Javascript
js实现淘宝浏览商品放大镜功能
2020/10/28 Javascript
在python中的socket模块使用代理实例
2014/05/29 Python
进一步探究Python的装饰器的运用
2015/05/05 Python
Python中http请求方法库汇总
2016/01/06 Python
分享Python开发中要注意的十个小贴士
2016/08/30 Python
Flask框架实现的前端RSA加密与后端Python解密功能详解
2019/08/13 Python
python爬虫 urllib模块发起post请求过程解析
2019/08/20 Python
Python如何执行精确的浮点数运算
2020/07/31 Python
利用python爬取有道词典的方法
2020/12/08 Python
使用python实现学生信息管理系统
2021/02/25 Python
汽车维修专业个人求职信范文
2014/01/01 职场文书
幼儿园六一儿童节文艺汇演主持词
2014/03/21 职场文书
党的群众路线整改落实情况汇报
2014/10/28 职场文书
分居协议书范本
2014/11/03 职场文书
五一放假通知怎么写
2015/08/18 职场文书
纯html+css实现奥运五环的示例代码
2021/08/02 HTML / CSS