-
手游APP軟件下載類網(wǎng)站織...
-
蔬菜鮮果配送類網(wǎng)站織夢(mèng)...
-
財(cái)稅記賬工商注冊(cè)認(rèn)證類...
-
物流快運(yùn)速遞類網(wǎng)站織夢(mèng)...
-
儀器儀表科技公司類網(wǎng)站...
-
電腦系統(tǒng)軟件下載類網(wǎng)站...
-
食品百貨英文外貿(mào)類網(wǎng)站...
-
水利工程施工類網(wǎng)站織夢(mèng)...
-
營(yíng)銷型無縫鋼管定制生產(chǎn)...
-
儀器分析儀類網(wǎng)站織夢(mèng)模...
-
人力資源管理類網(wǎng)站織夢(mèng)...
-
展覽展會(huì)信息類網(wǎng)站織夢(mèng)...
-
裝飾建材公司類網(wǎng)站織夢(mèng)...
-
玩具動(dòng)漫類網(wǎng)站織夢(mèng)模板...
-
中英雙語律師事務(wù)所類網(wǎng)...
-
貂絨大衣服裝設(shè)計(jì)類網(wǎng)站...
-
鋼結(jié)構(gòu)崗?fù)I(yíng)銷型織夢(mèng)網(wǎng)...
-
電子元件電路板類網(wǎng)站織...
-
精工機(jī)械軸承生產(chǎn)廠家類...
-
網(wǎng)站模板資源下載類網(wǎng)站...
edecms 的cn_substr_utf8字符串截取函數(shù)商榷
在phpsir看到的這篇文章,主要是說下dedecms 的cn_substr_utf8函數(shù)好像有些問題,研究dedecms的朋友可以看下
在dedecms里面cn_substr_utf8函數(shù)代碼如下
/*** utf-8中文截取,單字節(jié)截取模式** @access public* @param string $str 需要截取的字符串* @param int $slen 截取的長(zhǎng)度* @param int $startdd 開始標(biāo)記處* @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以下版本,與數(shù)據(jù)庫varchar一致,這里使用按字節(jié)截取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]) )
一行可能會(huì)造成截取后多了一個(gè)字符,可以改為
if(strlen($str) < $length + strlen($ar[0][$i]) -1 )
測(cè)試代碼
$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) {