用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 相关文章推荐
PHP date函数参数详解
Nov 27 PHP
php adodb操作mysql数据库
Mar 19 PHP
PHP以指定字段为索引返回数据库所取的数据数组
Jun 30 PHP
PHP字符串中特殊符号的过滤方法介绍
Feb 18 PHP
PHP循环输出指定目录下的所有文件和文件夹路径例子(简单实用)
May 10 PHP
php计算程序运行时间的简单例子分享
May 10 PHP
PHP函数eval()介绍和使用示例
Aug 20 PHP
php+mysqli实现批量执行插入、更新及删除数据的方法
Jan 29 PHP
php+ajax 实现输入读取数据库显示匹配信息
Oct 08 PHP
PHP生成推广海报的方法分享
Apr 22 PHP
PHP数组Key强制类型转换实现原理解析
Sep 01 PHP
PHP实现倒计时功能
Nov 16 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
Zend公司全球首推PHP认证
2006/10/09 PHP
php调用nginx的mod_zip模块打包ZIP文件
2014/06/11 PHP
Apache启动报错No space left on device: AH00023该怎么解决
2015/10/16 PHP
浅析php设计模式之数据对象映射模式
2016/03/03 PHP
浅谈Laravel模板实体转义带来的坑
2019/10/22 PHP
PHP实现Snowflake生成分布式唯一ID的方法示例
2020/08/30 PHP
event.srcElement+表格应用
2006/08/29 Javascript
浅析showModalDialog数据缓存问题(用禁止浏览器缓存解决)
2013/07/09 Javascript
javaScript使用EL表达式的几种方式
2014/05/27 Javascript
JavaScript常用脚本汇总(三)
2015/03/04 Javascript
全面解析Bootstrap中Carousel轮播的使用方法
2016/06/13 Javascript
js调用屏幕宽度的简单方法
2016/11/14 Javascript
AngularJS 在同一个界面启动多个ng-app应用模块详解
2016/12/20 Javascript
jquery 正整数数字校验正则表达式
2017/01/10 Javascript
Ionic2开发环境搭建教程
2020/08/20 Javascript
vue引入jq插件的实例讲解
2017/09/12 Javascript
vue.js 2.0实现简单分页效果
2019/07/29 Javascript
js实现图片无缝循环轮播
2019/10/28 Javascript
Vue使用Three.js加载glTF模型的方法详解
2020/06/14 Javascript
在Python中使用元类的教程
2015/04/28 Python
教大家使用Python SqlAlchemy
2016/02/12 Python
Python 3实战爬虫之爬取京东图书的图片详解
2017/10/09 Python
Django 响应数据response的返回源码详解
2019/08/06 Python
python网络爬虫 CrawlSpider使用详解
2019/09/27 Python
Python实现图像去噪方式(中值去噪和均值去噪)
2019/12/18 Python
Michael Kors美国官网:美式奢侈生活风格的代表
2016/11/25 全球购物
PAUL HEWITT手表美国站:德国北部时尚生活配饰品牌,船锚元素
2017/11/18 全球购物
卫校中专生的自我评价
2014/01/15 职场文书
开业庆典答谢词
2014/01/18 职场文书
银行行长竞聘演讲稿
2014/04/23 职场文书
产品销售计划书
2014/05/04 职场文书
党员承诺书怎么写
2014/05/20 职场文书
优秀管理者事迹材料
2014/05/22 职场文书
小学班级标语口号大全
2015/12/26 职场文书
redis实现的四种常见限流策略
2021/06/18 Redis
VW、VH适配移动端的解决方案与常见问题
2023/05/21 HTML / CSS