-
物流快运速递类网站织梦...
-
仪器分析仪类网站织梦模...
-
财富管理培训咨询类网站...
-
茶几茶盘类网站织梦模板...
-
QQ个性空间日志资讯类网...
-
网站建设万词霸屏SEO优化...
-
新闻博客资讯类网站织梦...
-
仪器仪表科技公司类网站...
-
产品展示柜台类网站织梦...
-
汽车用品配件类网站织梦...
-
防腐木材工程类网站织梦...
-
网络品牌广告设计类网站...
-
鲜花商城购物类网站织梦...
-
搬家搬迁公司类网站织梦...
-
财经新闻资讯网类织梦模...
-
装修设计类网站织梦模板...
-
精工机械轴承加工类网站...
-
智能电子玩具类网站织梦...
-
中英双语窗帘门窗设计类...
-
家政服务保姆月嫂类网站...
edecms 的cn_substr_utf8字符串截取函数商榷
在phpsir看到的这篇文章,主要是说下dedecms 的cn_substr_utf8函数好像有些问题,研究dedecms的朋友可以看下
在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) < $start+1) {return '';}preg_match_all("/./su", $str, $ar);$str = '';$tstr = '';</p> <p> //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取for ($i=0; isset($ar[0][$i]); $i++) {if(strlen($tstr) < $start) {$tstr .= $ar[0][$i];} else {if(strlen($str) < $length + strlen($ar[0][$i]) ) {$str .= $ar[0][$i];} else {break;}}}return $str;}}
其中
if(strlen($str) < $length + strlen($ar[0][$i]) )
一行可能会造成截取后多了一个字符,可以改为
if(strlen($str) < $length + strlen($ar[0][$i]) -1 )
测试代码
$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));</p> <p>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+1) {return '';}if($str_len < $startdd + $slen || $slen==0) {$slen = $str_len - $startdd;}$enddd = $startdd + $slen - 1;for ($i=0;$i<$str_len;$i++) {if($startdd==0) {


