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获取类中常量,属性,及方法列表的方法
Apr 09 PHP
火车头discuz6.1 完美采集的php接口文件
Sep 13 PHP
PHP 缓存实现代码及详细注释
May 16 PHP
PHP中通过加号合并数组的一个简单方法分享
Jan 27 PHP
php curl常见错误:SSL错误、bool(false)
Dec 28 PHP
关于PHP语言构造器介绍
Jul 08 PHP
PHP 使用redis简单示例分享
Mar 05 PHP
php使用curl简单抓取远程url的方法
Mar 13 PHP
php通过sort()函数给数组排序的方法
Mar 18 PHP
PHP编写daemon process 实例详解
Nov 13 PHP
详谈配置phpstorm完美支持Codeigniter(CI)代码自动完成(代码提示)
Apr 07 PHP
PHP 文件上传限制问题
Sep 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
基于mysql的bbs设计(三)
2006/10/09 PHP
php 文件上传代码(限制jpg文件)
2010/01/05 PHP
php中通过虚代理实现延迟加载的实现代码
2011/06/10 PHP
对淘宝URL中ID提取的PHP代码
2013/09/01 PHP
PHP实现自动识别Restful API的返回内容类型
2015/02/07 PHP
Smarty中的注释和截断功能介绍
2015/04/09 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
PHP Callable强制指定回调类型的方法
2016/08/30 PHP
PHP面向对象多态性实现方法简单示例
2017/09/27 PHP
laravel中的fillable和guarded属性详解
2019/10/23 PHP
php数组函数array_push()、array_pop()及array_shift()简单用法示例
2020/01/26 PHP
javascript获得服务器端控件的ID的实现代码
2011/12/28 Javascript
javascript读取xml实现javascript分页
2013/12/13 Javascript
javascript与有限状态机详解
2014/05/08 Javascript
JQuery中ajax方法访问web服务实例
2015/07/18 Javascript
JS+CSS实现仿雅虎另类滑动门切换效果
2015/10/13 Javascript
HTML中setCapture、releaseCapture 使用方法浅析
2016/09/25 Javascript
jquery.flot.js简单绘制折线图用法示例
2017/03/13 Javascript
JavaScript实现树的遍历算法示例【广度优先与深度优先】
2017/10/26 Javascript
Node.js模块全局安装路径配置方法
2018/05/17 Javascript
vue首次赋值不触发watch的解决方法
2018/09/11 Javascript
Vue将props值实时传递 并可修改的操作
2020/08/09 Javascript
python使用rsa加密算法模块模拟新浪微博登录
2014/01/22 Python
python实现用于测试网站访问速率的方法
2015/05/26 Python
Python插件virtualenv搭建虚拟环境
2017/11/20 Python
使用coverage统计python web项目代码覆盖率的方法详解
2019/08/05 Python
python3.7实现云之讯、聚合短信平台的短信发送功能
2019/09/26 Python
python写一个随机点名软件的实例
2019/11/28 Python
浅谈Python访问MySQL的正确姿势
2020/01/07 Python
Python插件机制实现详解
2020/05/04 Python
使用HTML5 Canvas绘制直线或折线等线条的方法讲解
2016/03/14 HTML / CSS
初中同学聚会邀请函
2014/02/03 职场文书
初中教师个人工作总结
2015/02/10 职场文书
行政介绍信范文
2015/05/04 职场文书
初中体育教学随笔
2015/08/15 职场文书
如何通过cmd 连接阿里云服务器
2022/04/18 Servers