***************begin itlife365 **
thinkphp使用函数substr截取中文字符串乱码的解决方法
在thinkphp的默认模版引擎里面提供了方法substr函数进行字符串的截取,使用格式如下,但是因为一个中文占用3个字符,所以截取的时候会
乱码。
<p>{$vo.content|htmlspecialchars_decode|substr=0,50}……</p>
发现热心的网友提交了解决方案,但是在扩展函数库里面,不能直接使用,需要加载或者拷贝到项目函数库中才能使用。
加载或者拷贝到项目函数库中才能使用
加载扩展函数库,
在相应的Action中中添加如下代码
Load('extend');
然后就可以在后续的方法或者前台页面进行调用了。
前台页面调用方法如下:
<p>{$vo.content|htmlspecialchars_decode|msubstr=0,50}……</p>
msubstr完整的函数说明如下:
msubstr($str, $start=0, $length, $charset="utf-8″, $suffix=true)
$str:要截取的字符串
$start=0:开始位置,默认从0开始
$length:截取长度
$charset="utf-8″:字符编码,默认UTF-8
$suffix=true:是否在截取后的字符后面显示省略号,默认true显示,false为不显示
<p>{$vo.itlife365|htmlspecialchars_decode|msubstr=0,50,'utf-8',false}</p>
对应的实现方法在文件ThinkPHP\Extend\Function\extend.php中
/**
*itlife365 简单街购物平台jiandanjie
* 字符串截取,支持中文和其他编码
* @static
* @access public
* @param string $str 需要转换的字符串
* @param string $start 开始位置
* @param string $length 截取长度
* @param string $charset 编码格式
* @param string $suffix 截断显示字符
* @return string
*/
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true) {
if(function_exists("mb_substr"))
$slice = mb_substr($str, $start, $length, $charset);
elseif(function_exists('iconv_substr')) {
$slice = iconv_substr($str,$start,$length,$charset);
if(false === $slice) {
$slice = '';
}
}else{
$re['utf-8'] = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
$re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
$re['gbk'] = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
$re['big5'] = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/";
preg_match_all($re[$charset], $str, $match);
$slice = join("",array_slice($match[0], $start, $length));
}
return $suffix ? $slice.'...' : $slice;
***************end itlife365 **itlife365 简单街购物平台jiandanjie
