Dedecms 的cn_substr_utf8字符串截取函数商榷
在PHPsir看到的这篇文章,主要是说下Dedecms 的cn_substr_utf8函数好像有些问题,研究Dedecms的朋友可以看下
在Dedecms里面 cn_substr_utf8 函数是这样的
代码如下:
05 | * @param string $str 需要截取的字符串 |
06 | * @param int $slen 截取的长度 |
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) { |
08 | if ($cfg_soft_lang== 'utf-8' ) { |
09 | return cn_substr_utf8($str, $slen, $startdd); |
13 | $str_len = strlen($str); |
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++) { |
|
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。