用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 相关文章推荐
Apache设置虚拟WEB
Oct 09 PHP
PHP面向对象编程快速入门
Dec 14 PHP
php版淘宝网查询商品接口代码示例
Jun 17 PHP
php自定义加密与解密程序实例
Dec 31 PHP
PHP中的替代语法介绍
Jan 09 PHP
Windows7下的php环境配置教程
Feb 28 PHP
PHP SESSION的增加、删除、修改、查看操作
Mar 20 PHP
php比较两个字符串长度的方法
Jul 13 PHP
php字符串比较函数用法小结(strcmp,strcasecmp,strnatcmp及strnatcasecmp)
Jul 18 PHP
php array_walk 对数组中的每个元素应用用户自定义函数详解
Nov 18 PHP
PHP常用算法和数据结构示例(必看篇)
Mar 15 PHP
PHP使用JpGraph绘制折线图操作示例【附源码下载】
Oct 18 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中的类-什么叫类
2006/11/20 PHP
PHP中的cookie
2006/11/26 PHP
PHP开发负载均衡指南
2010/07/17 PHP
PHP获取photoshop写入图片文字信息的方法
2015/03/31 PHP
PHP封装的多文件上传类实例与用法详解
2017/02/07 PHP
Laravel框架路由和控制器的绑定操作方法
2018/06/12 PHP
SlideView 图片滑动(扩展/收缩)展示效果
2010/08/01 Javascript
js 表单提交后按钮变灰的实例代码
2013/08/16 Javascript
调用jQuery滑出效果时闪烁的解决方法
2014/03/27 Javascript
jQuery获取动态生成的元素示例
2014/06/15 Javascript
JQuery中$(document)是什么意思有什么作用
2014/07/21 Javascript
jQuery DOM删除节点操作指南
2015/03/03 Javascript
readonly和disabled属性的区别
2015/07/26 Javascript
jQuery实现的网页左侧在线客服效果代码
2015/10/23 Javascript
jquery实现超简单的瀑布流布局【推荐】
2017/03/08 Javascript
webpack进阶——缓存与独立打包的用法
2017/08/02 Javascript
webpack写jquery插件的环境配置
2017/12/21 jQuery
原生JS写Ajax的请求函数功能
2017/12/22 Javascript
微信小程序实现聊天对话(文本、图片)功能
2018/07/06 Javascript
Vue 实现展开折叠效果的示例代码
2018/08/27 Javascript
JavaScript fetch接口案例解析
2018/08/30 Javascript
jQuery中each和js中forEach的区别分析
2019/02/27 jQuery
Vue 数组和对象更新,但是页面没有刷新的解决方式
2019/11/09 Javascript
js 数据类型判断的方法
2020/12/03 Javascript
[49:35]KG vs SECRET 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
Python 正则表达式操作指南
2009/05/04 Python
Python端口扫描简单程序
2016/11/10 Python
Python实现合并两个列表的方法分析
2018/05/28 Python
python中使用psutil查看内存占用的情况
2018/06/11 Python
Python之list对应元素求和的方法
2018/06/28 Python
Python类的绑定方法和非绑定方法实例解析
2020/03/04 Python
Nike荷兰官方网站:Nike.com (NL)
2018/04/19 全球购物
英国第一职业高尔夫商店:Clickgolf.co.uk
2020/11/18 全球购物
DELPHI面试题研发笔试试卷
2015/11/08 面试题
社区五一劳动节活动总结
2015/02/09 职场文书
css如何把元素固定在容器底部的四种方式
2022/06/16 HTML / CSS