• php解决中文截取乱码问题


     
    $str = '利要a-符e:r ttnx节小-子s区。vh;peh。例t来个oe体字n代gb节看t通c eu是的soS至什tna过码 t;Ie看C实e/,字le A来具8y么a)n=于ndg是r于 0tmt现码 e0ssf8单下s(uo别e的以ieh过aatx和t接要u几这看 nsw Ihrr用字 mgtts上就eg cAei的nwo码e跳h,t编'; /* *在某篇文章中截取一段字符串,多余的用省略号...表示,并且防止中文乱码 *$param1 string要截取的字符串 $str 注意:这里是utf-8编码 *$param2 int截取字符串的长度 $len *返回值 成功返回所要截取的字符串,失败为空 */
     
    function str($str='',$len=0){
    //检查参数
    if(!is_string($str) || !is_int($len)){
    return '';
    }
    $length = strlen($str);
    if($length <= 0 ){
    return '';
    }
    if($len>=$length){
    return $str;
    }
    //初始化,统计字符串的个数,
    $count = 0;
    for($i=0;$i<$length;$i++){
    //达到个数跳出循环,$i即为要截取的长度
    if($count == $len){
    break;
    }
    $count++;
    //ord函数是获取字符串的ASCII编码,大于等于十六进制0x80的字符串即为中文字符串
    if(ord($str{$i}) >= 0x80){
    $i +=2;//中文编码的字符串的长度再加2
    }
    } //如果要截取的个数超过了字符串的总个数,那么我们返回全部字符串,不带省略号
    if($len > $count){
    return $str;
    }else{
    return substr($str,0,$i).'...';
    }
    }
    
    //使用mbstring扩展库的mb_substr()截取就不会出现乱码了。
    可以用mb_substr()/mb_strcut()这个函数,mb_substr()/mb_strcut()的用法与substr()相似,只是在mb_substr()/mb_strcut最后要加入多一个参数,以设定字符串的编码,但是一般的服务器都没打开php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。
    mb_substr($v['p_descript'],0,12,"utf-8")
  • 相关阅读:
    day77
    75
    ElasticSearch集群的配置
    虚拟机VMware Workstation搭建Linux集群——VMware Tools的安装与配置
    ElasticSearch通过Rest Http API完成基本操作
    Maven笔记
    Oracle通过PL/SQL Developer导出数据为CSV格式,VARCHAR2类型的字段如果存入的是数值(例如3307830000004059)太长,最后一位会被置为0
    Redis的安装与配置
    2017 3月份以来入职感受
    Java设计模式(05-- 代理模式模式 )
  • 原文地址:https://www.cnblogs.com/lxlry/p/6225215.html
Copyright © 2020-2023  润新知