用PHP将Unicode 转化为UTF-8的实现方法(推荐)


Posted in PHP onFebruary 08, 2017

实例如下:

function unescape($str) {
  $str = rawurldecode($str);
  preg_match_all("/(?:%u.{4})|&#x.{4};|&#\d+;|.+/U",$str,$r);
  $ar = $r[0];
  //print_r($ar);
  foreach($ar as $k=>$v) {
    if(substr($v,0,2) == "%u"){
      $ar[$k] = iconv("UCS-2BE","UTF-8",pack("H4",substr($v,-4)));
 }
    elseif(substr($v,0,3) == "&#x"){
      $ar[$k] = iconv("UCS-2BE","UTF-8",pack("H4",substr($v,3,-1)));
 }
    elseif(substr($v,0,2) == "&#") {
       
      $ar[$k] = iconv("UCS-2BE","UTF-8",pack("n",substr($v,2,-1)));
    }
  }
  return join("",$ar);
}
echo unescape("紫星蓝");

今天有用户反馈,表单系统用户提交的数据中文会乱码。测试发现问题出在 iconv 转换上。
iconv('UCS-2',
'GBK',
'中文')
Google

搜索发现,原因是 Linux 服务器上 UCS-2 编码方式与 Winodws 不一致。

于是,我改成

 iconv('UCS-2BE',
'GBK',
'中文')
 试试,中文正常了

以下是有关两个平台

UCS-2 编码的潜规则:

1、 UCS-2 不等于 UTF-16。 UTF-16 每个字节使用 ASCII 字符范围编码,而 UCS-2 对每个字节的编码可以超出 ASCII 字符范围。UCS-2 和 UTF-16 对每个字符至多占两个字节,但是他们的编码是不一样的。

2、对于 UCS-2, windows 下默认是 UCS-2LE。用 MultibyteToWidechar(或者A2W)生成的是 UCS-2LE 的 unicode。windows记事本可以将文本保存为 UCS-2BE,相当于多了层转换。

3、 对于 UCS-2, linux 下默认是 UCS-2BE。用iconv(指定UCS-2)来转换生成的是 UCS-2BE 的 unicode。如果转换windows平台过来的 UCS-2, 需要指定 UCS-2LE。

4、鉴于windows和linux等多个平台对 UCS-2 的理解不同(UCS-2LE,UCS-2BE)。MS 主张 unicode 有个引导标志(UCS-2LE FFFE, UCS-2BE FEFF),以表明下面的字符是 unicode 并且判别 big-endian 或 little-endian。 所以从 windows 平台过来的数据发现有这个前缀,不用慌张。

5、 linux 的编码输出,比如从文件输出,从 printf 输出,需要控制台做适当的编码匹配(如果编码不匹配,一般和该程序编译时的编码有若干关系),而控制台的转换输入需要查看当前的系统编码。比如控制台当前的编码是 UTF-8, 那么 UTF-8 编码的东西能正确显示,GBK 就不能;同样,当前编码是 GBK, 就能显示 GBK 编码,后来的系统应该更智能的处理好更多的转换了。不过通过 putty 等终端还是需要设置好终端的编码转换以解除乱码的烦恼。

以上这篇用PHP将Unicode 转化为UTF-8的实现方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
如何去掉文章里的 html 语法
Oct 09 PHP
PHP操作xml代码
Jun 17 PHP
在PHP中实现Javascript的escape()函数代码
Aug 08 PHP
重新封装zend_soap实现http连接安全认证的php代码
Jan 12 PHP
php函数的常用方法及注意之处小结
Jul 10 PHP
PHP中最容易忘记的一些知识点总结
Apr 28 PHP
php中strtotime函数用法详解
Nov 15 PHP
php使用递归计算文件夹大小
Dec 24 PHP
深入讲解PHP的Yii框架中的属性(Property)
Mar 18 PHP
PHP7.1新功能之Nullable Type用法分析
Sep 26 PHP
php获取服务器操作系统相关信息的方法
Oct 08 PHP
laravel框架添加数据,显示数据,返回成功值的方法
Oct 11 PHP
一键生成各种尺寸Icon的php脚本(实例)
Feb 08 #PHP
php正则提取html图片(img)src地址与任意属性的方法
Feb 08 #PHP
PHP正则匹配反斜杠'\'和美元'$'的方法
Feb 08 #PHP
php利用嵌套数组拼接与解析json的方法
Feb 07 #PHP
php获取文件名称和扩展名的方法
Feb 07 #PHP
php 常用的系统函数
Feb 07 #PHP
thinkphp修改配置进入默认首页的方法
Feb 07 #PHP
You might like
php的webservice的wsdl的XML无法显示问题的解决方法
2014/03/11 PHP
php使用Jpgraph创建折线图效果示例
2017/02/15 PHP
php实现批量上传数据到数据库(.csv格式)的案例
2017/06/18 PHP
顶部缓冲下拉菜单导航特效的JS代码
2013/08/27 Javascript
查看大图功能代码jquery版
2013/11/05 Javascript
javascript中Array数组的迭代方法实例分析
2015/02/04 Javascript
简单的分页代码js实现
2016/05/17 Javascript
Vue.js在使用中的一些注意知识点
2017/04/29 Javascript
Angular2环境搭建具体操作步骤(推荐)
2017/08/04 Javascript
浅谈Vuejs Prop基本用法
2017/08/17 Javascript
React操作真实DOM实现动态吸底部的示例
2017/10/23 Javascript
javascript代码优化的8点总结
2018/01/29 Javascript
详解VUE自定义组件中用.sync修饰符与v-model的区别
2018/06/26 Javascript
python 2.6.6升级到python 2.7.x版本的方法
2016/10/09 Python
Python 中的lambda函数介绍
2018/10/10 Python
解决python opencv无法显示图片的问题
2018/10/28 Python
python之生产者消费者模型实现详解
2019/07/27 Python
django将网络中的图片,保存成model中的ImageField的实例
2019/08/07 Python
Python 日志logging模块用法简单示例
2019/10/18 Python
python中从for循环延申到推导式的具体使用
2019/11/29 Python
pytorch方法测试——激活函数(ReLU)详解
2020/01/15 Python
pandas 强制类型转换 df.astype实例
2020/04/09 Python
Django中日期时间型字段进行年月日时分秒分组统计
2020/11/27 Python
澳大利亚在线生活方式商店:Mytopia
2018/07/08 全球购物
Nebula美国官网:便携式投影仪
2019/03/15 全球购物
英国现代家具和照明购物网站:Heal’s
2019/10/30 全球购物
升职自荐信范文
2013/10/05 职场文书
卫校毕业生自我鉴定
2013/10/31 职场文书
学前教育求职自荐信范文
2013/12/25 职场文书
如何写一封打动人心的求职信
2014/02/17 职场文书
小学毕业感言300字
2014/02/19 职场文书
省级优秀毕业生主要事迹
2014/05/29 职场文书
群众路线教师自我剖析材料
2014/09/29 职场文书
委托书格式范文
2015/01/28 职场文书
物流业务员岗位职责
2015/04/03 职场文书
MySQL事务的ACID特性以及并发问题方案
2022/07/15 MySQL