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 代码规范小结
Mar 08 PHP
详解php的魔术方法__get()和__set()使用介绍
Sep 19 PHP
PHP生成压缩文件实例
Feb 07 PHP
PHP实现支持SSL连接的SMTP邮件发送类
Mar 05 PHP
php将html转成wml的WAP标记语言实例
Jul 08 PHP
php使用APC实现实时上传进度条功能
Oct 26 PHP
smarty高级特性之过滤器的使用方法
Dec 25 PHP
php采集神器cURL使用方法详解
Feb 19 PHP
mac系统下为 php 添加 pcntl 扩展
Aug 28 PHP
php压缩文件夹最新版
Jul 18 PHP
PHP实现文件上传操作和封装
Mar 04 PHP
如何用Laravel包含你自己的帮助函数
May 27 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投票系统防刷票判断流程分析
2012/02/04 PHP
sql注入与转义的php函数代码
2013/06/17 PHP
学习php设计模式 php实现门面模式(Facade)
2015/12/07 PHP
PHP单例模式定义与使用实例详解
2017/02/06 PHP
Yii实现复选框批量操作实例代码
2017/03/15 PHP
Laravel中10个有用的用法小结
2019/05/06 PHP
JQuery CSS样式控制 学习笔记
2009/07/23 Javascript
javascript 动态调整图片尺寸实现代码
2009/12/28 Javascript
js实现的切换面板实例代码
2013/06/17 Javascript
将文本输入框内容加入表中的js代码
2013/08/18 Javascript
jquery操作 iframe的方法
2014/12/03 Javascript
jQuery 1.9.1源码分析系列(十)事件系统之主动触发事件和模拟冒泡处理
2015/11/24 Javascript
浅析Node.js实现HTTP文件下载
2016/08/05 Javascript
基于JavaScript实现鼠标箭头移动图片跟着移动
2016/08/30 Javascript
微信小程序 picker 组件详解及简单实例
2017/01/10 Javascript
jQuery弹出窗口简单实现代码
2017/03/09 Javascript
jquery实现动态改变css样式的方法分析
2019/05/27 jQuery
JavaScript读取本地文件常用方法流程解析
2020/10/12 Javascript
Vue常用API、高级API的相关总结
2021/02/02 Vue.js
Python中的hypot()方法使用简介
2015/05/18 Python
Python多进程池 multiprocessing Pool用法示例
2018/09/07 Python
python实现简单的文字识别
2018/11/27 Python
详解js文件通过python访问数据库方法
2019/03/03 Python
python实现植物大战僵尸游戏实例代码
2019/06/10 Python
python之mock模块基本使用方法详解
2019/06/27 Python
wxPython多个窗口的基本结构
2019/11/19 Python
Python退出时强制运行一段代码的实现方法
2020/04/29 Python
Python3批量创建Crowd用户并分配组
2020/05/20 Python
Keras SGD 随机梯度下降优化器参数设置方式
2020/06/19 Python
利用css3如何设置没有上下边的列表间隔线
2017/07/03 HTML / CSS
世界上最大的餐具公司:Oneida
2016/12/17 全球购物
世界知名接发和假发品牌:Poze Hair
2017/03/08 全球购物
教育学习自我评价
2014/02/03 职场文书
运动会演讲稿
2014/05/07 职场文书
幼儿园开学报名通知
2015/07/16 职场文书
Java练习之潜艇小游戏的实现
2022/03/16 Java/Android