手机
当前位置:查字典教程网 >编程开发 >php教程 >解析使用substr截取UTF-8中文字符串出现乱码的问题
解析使用substr截取UTF-8中文字符串出现乱码的问题
摘要:我们知道有时候使用substr来截取UTF-8中文字符串的时候,经常会出现乱码,为什么会出现这样的问题呢,本文告诉你答案。看这样一段代码吧(...

我们知道有时候使用substr来截取UTF-8中文字符串的时候,经常会出现乱码,为什么会出现这样的问题呢,本文告诉你答案。

看这样一段代码吧(字符编码为UTF-8):

复制代码 代码如下:

<?

$str = '都知道strlen与mb_strlen是求字符串长度的函数';

echo strlen($str)'.<br />'.mb_strlen($str,'utf-8');

?>

运行上述代码,返回值如下:

66

34

怎么样?strlen中,中文是三个字节的长度,英文则是一个字节的长度!mb_strlen中,都被计算为一字节的长度!所以,我们有时候用substr来截取UTF-8中文字符串的时候,经常会出现乱码,就是这个原因了!

下面提供一个截取UTF-8字符串的函数:

复制代码 代码如下:

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;

}

使用例子:

复制代码 代码如下:

<?

$str = '有效期最长三个月,超过有效期系统将自动删除本条信息';

//echo strlen($str);

//echo '<hr />'.mb_strlen($str,'utf-8');

echo '<hr />'.$str;

echo '<hr />'.cutstr($str,24);

?>

【解析使用substr截取UTF-8中文字符串出现乱码的问题】相关文章:

解决PHP导出CSV文中文乱码问题

使用sockets:从新闻组中获取文章(二)

支持中文的PHP按字符串长度分割成数组代码

php截取指定2个字符之间字符串的方法

PHP使用flock实现文件加锁的方法

php使用substr()和strpos()联合查找字符串中某一特定字符的方法

使用sockets:从新闻组中获取文章(三)

PHP二进制与字符串之间的相互转换

php使用cookie实现记住用户名和密码实现代码

substr()函数中文版

精品推荐
分类导航