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 相关文章推荐
web方式ftp
Oct 09 PHP
实用函数10
Nov 08 PHP
AMFPHP php远程调用(RPC, Remote Procedure Call)工具 快速入门教程
May 10 PHP
php学习之简单计算器实现代码
Jun 09 PHP
探讨各种PHP字符串函数的总结分析
Jun 05 PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
Jun 09 PHP
php json_encode值中大括号与花括号区别
Sep 30 PHP
Laravel 5框架学习之Blade 简介
Apr 08 PHP
php根据用户语言跳转相应网页
Nov 04 PHP
smarty高级特性之过滤器的使用方法
Dec 25 PHP
YII使用url组件美化管理的方法
Dec 28 PHP
PHP微信支付结果通知与回调策略分析
Jan 10 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 文件上传代码(限制jpg文件)
2010/01/05 PHP
php获取文件夹路径内的图片以及分页显示示例
2014/03/11 PHP
php+mysql删除指定编号员工信息的方法
2015/01/14 PHP
详解PHP中curl_multi并发的实现
2020/06/08 PHP
基于JQuery的asp.net树实现代码
2010/11/30 Javascript
js DOM 元素ID就是全局变量
2012/09/20 Javascript
jQuery使用数组编写图片无缝向左滚动
2012/12/11 Javascript
JavaScript AJAX之惰性载入函数
2014/08/27 Javascript
DOM基础教程之模型中的模型节点
2015/01/19 Javascript
基于jQuery实现选取月份插件附源码下载
2015/12/28 Javascript
jQuery页面弹出框实现文件上传
2017/02/09 Javascript
详解使用webpack打包编写一个vue-toast插件
2017/11/08 Javascript
three.js实现3D视野缩放效果
2017/11/16 Javascript
Vue模拟数据,实现路由进入商品详情页面的示例
2018/08/31 Javascript
使用ThinkJs搭建微信中控服务的实现方法
2019/08/08 Javascript
解决layui 表单元素radio不显示渲染的问题
2019/09/04 Javascript
VUE动态生成word的实现
2020/07/26 Javascript
JavaScript实现无限轮播效果
2020/11/19 Javascript
原生JavaScript实现购物车
2021/01/10 Javascript
web.py中调用文件夹内模板的方法
2014/08/26 Python
使用pandas对矢量化数据进行替换处理的方法
2018/04/11 Python
selenium+python截图不成功的解决方法
2019/01/30 Python
Python分割训练集和测试集的方法示例
2019/09/19 Python
对python中assert、isinstance的用法详解
2019/11/27 Python
python打印异常信息的两种实现方式
2019/12/24 Python
Python是怎样处理json模块的
2020/07/16 Python
上海方立数码笔试题
2013/10/18 面试题
2014年上半年工作自我评价
2014/01/18 职场文书
大专毕业自我鉴定
2014/02/04 职场文书
升学宴主持词
2014/04/02 职场文书
莫言诺贝尔获奖演讲稿
2014/05/21 职场文书
记账会计岗位职责
2014/06/16 职场文书
乡镇党员干部四风对照检查材料思想汇报
2014/09/27 职场文书
部门群众路线教育实践活动对照检查材料思想汇报
2014/10/07 职场文书
2014年作风建设剖析材料
2014/10/23 职场文书
2015年乡镇统计工作总结
2015/04/22 职场文书