本文实例讲述了PHP实现Unicode编码相互转换的方法。分享给大家供大家参考,具体如下:
PHP;">
PHP
/**
* $str 原始中文字符串
* $encoding 原始字符串的编码,默认utf-8
* $prefix 编码后的前缀,默认""
* $postfix 编码后的后缀,默认";"
*/
function unicode_encode($str,$encoding = 'utf-8',$prefix = '',$postfix = ';') {
//将字符串拆分
$str = iconv("UTF-8","gb2312",$str);
$cind = 0;
$arr_cont = array();
for ($i = 0; $i < strlen($str); $i++) {
if (strlen(substr($str,$cind,1)) > 0) {
if (ord(substr($str,1)) < 0xA1) { //如果为英文则取1个字节
array_push($arr_cont,substr($str,1));
$cind++;
} else {
array_push($arr_cont,2));
$cind+=2;
}
}
}
foreach ($arr_cont as &$row) {
$row = iconv("gb2312","UTF-8",$row);
}
//转换Unicode码
foreach ($arr_cont as $key => $value) {
$unicodestr.= $prefix . base_convert(bin2hex(iconv('utf-8','UCS-4',$value)),16,10) .$postfix;
}
return $unicodestr;
}
/**
* $str Unicode编码后的字符串
* $decoding 原始字符串的编码,默认utf-8
* $prefix 编码字符串的前缀,默认""
* $postfix 编码字符串的后缀,默认";"
*/
function unicode_decode($unistr,$postfix = ';') {
$arruni = explode($prefix,$unistr);
$unistr = '';
for ($i = 1,$len = count($arruni); $i < $len; $i++) {
if (strlen($postfix) > 0) {
$arruni[$i] = substr($arruni[$i],strlen($arruni[$i]) - strlen($postfix));
}
$temp = intval($arruni[$i]);
$unistr .= ($temp < 256) ? chr(0) . chr($temp) : chr($temp / 256) . chr($temp % 256);
}
return iconv('UCS-2',$encoding,$unistr);
}
$str = "www.jb51.cc";
$unistr = unicode_encode($str);
$unistr2 = unicode_decode($unistr);
echo $unistr . '
'; echo $unistr2 . '
'; $unistr = unicode_encode($str,'GBK','\\u'); $unistr2 = unicode_decode($unistr,'\\u'); echo $unistr . '
'; echo $unistr2 . '
';
'; echo $unistr2 . '
'; $unistr = unicode_encode($str,'GBK','\\u'); $unistr2 = unicode_decode($unistr,'\\u'); echo $unistr . '
'; echo $unistr2 . '
';
PS:这里再为大家提供几款Unicode编码转换操作相关工具供大家参考使用:
在线Unicode/中文转换工具:
在线中文汉字/ASCII码/Unicode编码互相转换工具:
更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》、《》、及《》
希望本文所述对大家PHP程序设计有所帮助。
原文链接:https://www.f2er.com/php/17554.html