dedecms 的cn_substr_utf8字符串截取函数商榷
在phpsir看到的这篇文章,主要是说下dedecms 的cn_substr_utf8函数好像有些问题,研究dedecms的朋友可以看下
在dedecms里面 cn_substr_utf8 函数是这样的
代码如下:
05 |
* @param string $str 需要截取的字符串 |
06 |
* @param int $slen 截取的长度 |
07 |
* @param int $startdd 开始标记处 |
10 |
if ( ! function_exists( 'cn_substr_utf8' )) {
|
11 |
function cn_substr_utf8($str, $length, $start=0) {
|
12 |
if (strlen($str) < $start+1) {
|
15 |
preg_match_all( "/./su" , $str, $ar);
|
18 |
</p> <p> //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 |
19 |
for ($i=0; isset($ar[0][$i]); $i++) {
|
20 |
if (strlen($tstr) < $start) {
|
23 |
if (strlen($str) < $length + strlen($ar[0][$i]) ) {
|
|
其中
代码如下:
1 |
if (strlen($str) < $length + strlen($ar[0][$i]) )
|
|
一行可能会造成截取后多了一个字符,可以考虑改为
代码如下:
1 |
if (strlen($str) < $length + strlen($ar[0][$i]) -1 )
|
|
测试代码如下
代码如下:
查看源码打印代码帮助
01 |
$f = "你好fasdfa你fasdf#e#" ;
|
02 |
$pos = strpos($f, '#e#' );
|
04 |
var_dump(cn_substr_utf8($f,$pos)); |
05 |
var_dump(cn_substr_utf82($f,$pos)); |
06 |
</p> <p> function cn_substr($str, $slen, $startdd=0) {
|
07 |
global $cfg_soft_lang; |
08 |
if ($cfg_soft_lang== 'utf-8' ) {
|
09 |
return cn_substr_utf8($str, $slen, $startdd);
|
13 |
$str_len = strlen($str); |
14 |
if ($str_len < $startdd+1) {
|
17 |
if ($str_len < $startdd + $slen || $slen==0) {
|
18 |
$slen = $str_len - $startdd; |
20 |
$enddd = $startdd + $slen - 1; |
21 |
for ($i=0;$i<$str_len;$i++) {
|
|