/**
* 将unicode转换成字符
* @param int $unicode
* @return string UTF-8字符
**/
function unicode2Char($unicode){
if($unicode < 128) return chr($unicode);
if($unicode < 2048) return chr(($unicode >> 6) + 192) .
chr(($unicode & 63) + 128);
if($unicode < 65536) return chr(($unicode >> 12) + 224) .
chr((($unicode >> 6) & 63) + 128) .
chr(($unicode & 63) + 128);
if($unicode < 2097152) return chr(($unicode >> 18) + 240) .
chr((($unicode >> 12) & 63) + 128) .
chr((($unicode >> 6) & 63) + 128) .
chr(($unicode & 63) + 128);
return false;
}
/**
* 将字符转换成unicode
* @param string $char 必须是UTF-8字符
* @return int
**/
function char2Unicode($char){
switch (strlen($char)){
case 1 : return ord($char);
case 2 : return (ord($char{1}) & 63) |
((ord($char{0}) & 31) << 6);
case 3 : return (ord($char{2}) & 63) |
((ord($char{1}) & 63) << 6) |
((ord($char{0}) & 15) << 12);
case 4 : return (ord($char{3}) & 63) |
((ord($char{2}) & 63) << 6) |
((ord($char{1}) & 63) << 12) |
((ord($char{0}) & 7) << 18);
default :
trigger_error(‘Character is not UTF-8!‘, E_USER_WARNING);
return false;
}
}
/**
* 全角转半角
* @param string $str
* @return string
**/
function sbc2Dbc($str){
return preg_replace_callback(
// 全角字符
‘/[\x{3000}\x{ff01}-\x{ff5f}]/u‘,
function ($matches) {
// 编码转换
// 0x3000是空格,特殊处理,其他全角字符编码-0xfee0即可以转为半角
return ($unicode=$this -> char2Unicode($matches[0])) == 0x3000 ? " " : (($code=$unicode-0xfee0) > 256 ? $this -> unicode2Char($code) : chr($code));
},
$str);
}
/**
* 半角转全角
* @param string $str
* @return string
**/
function dbc2Sbc($str){
return preg_replace_callback(
// 半角字符
‘/[\x{0020}\x{0020}-\x{7e}]/u‘,
function ($matches) {
// 编码转换
// 0x0020是空格,特殊处理,其他半角字符编码+0xfee0即可以转为全角
return ($unicode= $this -> char2Unicode($matches[0])) == 0x0020 ? $this -> unicode2Char(0x3000) : (($code=$unicode+0xfee0) > 256 ? $this -> unicode2Char($code) : chr($code));
},
$str);
}
//使用 方法
$str = ‘abc,你好!‘;
$str_q = $this -> sbc2Dbc($str); //全角转半角
$str_b = $this ->dbc2Sbc($str_q); //半角转全角