查看文章
 
Smarty下面UTF-8截取中文汉字出现乱码的解决方法
2008-11-05 14:33

在Smarty下面使用{$content[index]|truncate:30}截取中文字符串的时候会出现乱码,怎么解决呢?经过我一夜的搜索和试验找到了一个比较好的方法。

第一步:找到Smarty的libs\plugins\modifier.truncate.php文件,把该文件修改为:

<?php

/*
@Author:     wangcong83
@Blog:       http://hi.baidu.com/wangcong83
@Reference: http://hi.baidu.com/lssbing/blog/item/a0c5dc23c64fcd579922ed44.html
@Note:       这个解决办法是基于上面那个地址提到的方法进行的修改的,解决了中文截取过长的问题
*/

function smarty_modifier_truncate($string, $sublen = 80, $etc = '...', $break_words = false, $middle = false)
{
$start=0;
$code="UTF-8";
       if($code == 'UTF-8')
   {
       //如果有中文则减去中文的个数
       $cncount=cncount($string);
       if($cncount>($sublen/2))
       {
            $sublen=ceil($sublen/2);
       }
       else
       {
            $sublen=$sublen-$cncount;
       }
  
       $pa = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/";
       preg_match_all($pa, $string, $t_string);

       if(count($t_string[0]) - $start > $sublen) return join('', array_slice($t_string[0], $start, $sublen))."...";
       return join('', array_slice($t_string[0], $start, $sublen));
   }
   else
   {
       $start = $start*2;
       $sublen = $sublen*2;
       $strlen = strlen($string);
       $tmpstr = '';

       for($i=0; $i<$strlen; $i++)
       {
           if($i>=$start && $i<($start+$sublen))
           {
               if(ord(substr($string, $i, 1))>129)
               {
                   $tmpstr.= substr($string, $i, 2);
               }
               else
               {
                   $tmpstr.= substr($string, $i, 1);
               }
           }
           if(ord(substr($string, $i, 1))>129) $i++;
       }
       if(strlen($tmpstr)<$strlen ) $tmpstr.= "...";
       return $tmpstr;
   }

}


function cncount($str)
{
$len=strlen($str);
    $cncount=0;
  
    for($i=0;$i<$len;$i++)
   {
      $temp_str=substr($str,$i,1);
     
      if(ord($temp_str) > 127)
      {
          $cncount++;
      }
    }

    return ceil($cncount/3);
}

?>

第二步:把修改后的文件上传覆盖原来的modifier.truncate.php文件,然后用{$content[index]|truncate:30}方法可以完美截取中文字符串;


类别:php相关||添加到搜藏 |分享到i贴吧|浏览(470)|评论 (0)
 
最近读者:
 
网友评论:
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
     

   
帮助中心 | 空间客服 | 投诉中心 | 空间协议
©2012 Baidu