当我们使用PHP的substr()截取中文字符串时可能会出现乱码,出现这种原因是英文、数字(半角)为1字节(8位),中文(全角)为3字节,所以有可能出现substr()硬生生将中文字符串截断成两截,所以就会显示成乱码。PHP截取中文字符串出现乱码的方法如下:
在PHP中,有专门的mb_strlen和mb_substr函数,能够对中文进行长度计算和截取,但是,由于这些函数并非PHP的核心函数,所以一般的服务器都没打开php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。使用例子如下:
输出:这个例子是关于截
与b_substr()使用方法类似的函数还有mb_strcut,使用例子如下所示:
输出:这个例
从例子可以看出,mb_substr是按字来切分字符,而mb_strcut是按字节来切分字符,但是他们都不会产生半个字符的现象。
上面的方法虽然使用简单,但是是需要一定的条件的,下面的方法是在任何一台支持PHP的主机都可以实现截取中文字符的函数,代码如下所示:
127){ $res_string.=substr($string,$n,2); $n++; }else{ $res_string.=substr($string,$n,1); } if(++$count==$len){ break; } } return $res_string; } $str="关于截取中文字符串的示例"; echo substr_chinese_character($str,3); ?>
输出:关于截
通过上面介绍的两种方法(1、系统自带 2、自定义方法)就可以解决PHP截取中文字符串出现乱码的问题。