- A+
所属分类:PHP学习
我们知道有时候使用substr来截取UTF-8中文字符串的时候,经常会出现乱码,为什么会出现这样的问题呢,本文告诉你答案。
看这样一段代码吧(字符编码为UTF-8):
代码如下:
1 2 3 4 |
<? $str = '都知道strlen与mb_strlen是求字符串长度的函数'; echo strlen($str)'.<br />'.mb_strlen($str,'utf-8'); ?> |
运行上述代码,返回值如下:
66
34
怎么样?strlen中,中文是三个字节的长度,英文则是一个字节的长度!mb_strlen中,都被计算为一字节的长度!所以,我们有时候用substr来截取UTF-8中文字符串的时候,经常会出现乱码,就是这个原因了!
下面提供一个截取UTF-8字符串的函数:
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
function cutstr($sourcestr,$cutlength){ $returnstr = ''; $i = 0; $n = 0; $str_length = strlen($sourcestr); $mb_str_length = mb_strlen($sourcestr,'utf-8'); while(($n < $cutlength) && ($i <= $str_length)){ $temp_str = substr($sourcestr,$i,1); $ascnum = ord($temp_str); if($ascnum >= 224){ $returnstr = $returnstr.substr($sourcestr,$i,3); $i = $i + 3; $n++; } elseif($ascnum >= 192){ $returnstr = $returnstr.substr($sourcestr,$i,2); $i = $i + 2; $n++; } elseif(($ascnum >= 65) && ($ascnum <= 90)){ $returnstr = $returnstr.substr($sourcestr,$i,1); $i = $i + 1; $n++; } else{ $returnstr = $returnstr.substr($sourcestr,$i,1); $i = $i + 1; $n = $n + 0.5; } } if ($mb_str_length > $cutlength){ $returnstr = $returnstr . "..."; } return $returnstr; } |
使用例子:
代码如下:
1 2 3 4 5 6 7 |
<? $str = '有效期最长三个月,超过有效期系统将自动删除本条信息'; //echo strlen($str); //echo '<hr />'.mb_strlen($str,'utf-8'); echo '<hr />'.$str; echo '<hr />'.cutstr($str,24); ?> |
整理一个比较好用的代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
/** * PHP截取UTF-8字符串,解决半字符问题。 * 英文、数字(半角)为1字节(8位),中文(全角)为2字节 * @return 取出的字符串, 当$len小于等于0时, 会返回整个字符串 * @param $str 源字符串 * $len 左边的子串的长度 */ function utf_substr($str,$len){ for($i=0;$i<$len;$i++){ $temp_str=substr($str,0,1); if(ord($temp_str) > 127){ if($i<$len){ $new_str[]=substr($str,0,3); $str=substr($str,3); } }else{ $new_str[]=substr($str,0,1); $str=substr($str,1); } } return join($new_str); } |