dedecms 的cn_substr_utf8字符串截取函数商榷
发布时间:2018-02-13
在dedecms里面 cn_substr_utf8 函数是这样的 复制代码代码如下: /** * utf-8中文截取,单字节截取模式 * * @access public * @param string $str 需要截取的字符串 * @param int $slen 截取的长度 * @param int $startdd 开始标记处 * @return string */ if ( ! function_exists('cn_substr_utf8')) { function cn_substr_utf8($str, $length, $start=0) { if(strlen($str) //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for($i=0; isset($ar<0><$i>); $i++) { if(strlen($tstr) 其中 复制代码代码如下: if(strlen($str) 一行可能会造成截取后多了一个字符,可以考虑改为 复制代码代码如下: if(strlen($str) 测试代码如下 复制代码代码如下: $f = "你好fasdfa你fasdf#e#"; $pos = strpos($f,'#e#'); var_dump($pos); var_dump(cn_substr_utf8($f,$pos)); var_dump(cn_substr_utf82($f,$pos)); function cn_substr($str, $slen, $startdd=0) { global $cfg_soft_lang; if($cfg_soft_lang=='utf-8') { return cn_substr_utf8($str, $slen, $startdd); } $restr = ''; $c = ''; $str_len = strlen($str); if($str_len $startdd) { $restr .= $c; } if(ord($str<$i>)>0x80) { if($str_len>$i+1) { $c = $str<$i>.$str<$i+1>; } $i++; } else { $c = $str<$i>; } if($i >= $enddd) { if(strlen($restr)+strlen($c)>$slen) { break; } else { $restr .= $c; break; } } } return $restr; } function cn_substr_utf8($str, $length, $start=0) { if(strlen($str) $str = ''; $tstr = ''; //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for($i=0; isset($ar<0><$i>); $i++) { if(strlen($tstr) $tstr .= $ar<0><$i>; } else { if(strlen($str) $str .= $ar<0><$i>; } else { break; } } } return $str; } function cn_substr_utf82($str, $length, $start=0) { if(strlen($str) $str = ''; $tstr = ''; //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for($i=0; isset($ar<0><$i>); $i++) { if(strlen($tstr) $tstr .= $ar<0><$i>; } else { if(strlen($str) $str .= $ar<0><$i>; } else { break; } } } return $str; } 文章来源
更多文章 进入论坛 我要发帖