PHP用substr截取字符串出现中文乱码问题用mb_substr
PHP用substr截取字符串出现中文乱码问题用mb_substr
实例:mb_substr('截取中文乱码问题测试',0,5, 'utf-8');
语法 : string substr (string string, int start [, int length])
$rest = substr ("abcdef", 1); // returns "bcdef"
$rest = substr ("abcdef", 1, 3); // returns "bcd"
如果 start是负数,传回的字符串将会从 string结尾的第 start个字开始。
$rest = substr ("abcdef", -1); // returns "f"
$rest = substr ("abcdef", -2); // returns "ef"
$rest = substr ("abcdef", -3, 1); // returns "d"
如果有给予参数 length而且是正数时,传回的字符串将会从 start传回 length个字元。
如果有给予参数 length而且是负数时,传回的字符串将会结束于 string结尾的第 length个字元。
$rest = substr ("abcdef", 1, -1); // returns "bcde"
对于英文没有问题,我们测试一个中文
$rest = substr ("中国人", 1, -1); // returns "fdsafsda" 就是乱码了
这种截取字符的结果,肯定不是我们想要的结果,这种出现PHP substr中文乱码的情况,可能会导致程序无法正常运行。
解决办法主要有两种:
一、使用mbstring扩展库的mb_substr()截取就不会出现乱码了。
可以用mb_substr()/mb_strcut()这个函数,mb_substr()/mb_strcut()的用法与substr()相似,只是在mb_substr()/mb_strcut最后要加入多一个参数,以设定字符串的编码,
但是一般的服务器都没打开php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。
echo mb_substr("php中文字符encode",0,4,"utf-8");
如果未指定最后一个编码参数,会是三个字节为一个中文,这就是utf-8编码的特点,若加上utf-8字符集说明,所以,是以一个字为单位来截取的。
使用的时候要注意php文件的编码,和网页显示时的编码。使用这个mb_substr方法要事先知道字符串的编码,如果不知道编码,就需要判断,mbstring库还提供了mb_check_encoding来检验字符串编码,但还不完善。
PHP 自带几种字符串截取函数,其中常用到的就是 substr 和 mb_substr。前者在处理中文时,GBK 为 2 个长度单位,UTF 为 3 个长度单位,后者指定编码后,一个中文即为 1 个长度单位。
substr 有时会截 1/3 个中文或半个中文,会显示乱码,相对来说 mb_substr 更适合我们使用。不过有时候 mb_substr 就显得不那么好用了。例如我要显示一个小图片的简要信息,5 个中文正好,超过 5 个就截取前4再加上 ”…”,这样处理中文是没问题了,可是处理英文或数字,这样截取就太短了。
二、自己书写截取函数,但效率不如用mbstring扩展库来得高。下面是ecshop里面的截取UTF-8编码下字符串的函数。
1 function sub_str($str, $length = , $append = true) 2 { 3 $str = trim($str); 4 $strlength = strlen($str); 5 if ($length == || $length >= $strlength) 6 { 7 return $str; //截取长度等于或大于等于本字符串的长度,返回字符串本身 8 } 9 elseif ($length < ) //如果截取长度为负数 10 { 11 $length = $strlength + $length;//那么截取长度就等于字符串长度减去截取长度 12 if ($length < ) 13 { 14 $length = $strlength;//如果截取长度的绝对值大于字符串本身长度,则截取长度取字符串本身的长度 15 } 16 } 17 if (function_exists('mb_substr')) 18 { 19 $newstr = mb_substr($str, , $length, EC_CHARSET); 20 } 21 elseif (function_exists('iconv_substr')) 22 { 23 $newstr = iconv_substr($str, , $length, EC_CHARSET); 24 } 25 else 26 { 27 //$newstr = trim_right(substr($str, , $length)); 28 $newstr = substr($str, , $length); 29 } 30 if ($append && $str != $newstr) 31 { 32 $newstr .= '...'; 33 } 34 return $newstr; 35 }
转载于:https://www.cnblogs.com/zdz8207/p/PHP-substr-mb_substr.html
PHP用substr截取字符串出现中文乱码问题用mb_substr相关推荐
- php截取字符串后编码不对,php截取字符串出现中文乱码问题的解决
在之前的文章中我们给大家接好了php截取字符串的实现,以及php截取中文字符串的使用,那么我们在截取中文字符串的时候,很多时候都会出现乱码的问题,那么我们今天就给大家介绍php截取字符串出现中文乱码问 ...
- 解决在C#(.net)按字节数截取字符串最后出现乱码的问题
解决在C#(.net)按字节数截取字符串最后出现乱码的问题 参考文章: (1)解决在C#(.net)按字节数截取字符串最后出现乱码的问题 (2)https://www.cnblogs.com/xion ...
- php解析乱码字符串,PHP substr 截取字符串出现乱码问题解决方法[utf8与gb2312]
在PHP中,使substr函数截取字符串末位会出现乱码,因为中文UTF-8编码,每个汉字占3字节,而GB2312占2字节,英文占1字节,截取位不准确,造成断开的字符会把其后的..拉过来一起做一个字,所 ...
- httpclient工具类,post请求发送json字符串参数,中文乱码处理
在使用httpclient发送post请求的时候,接收端中文乱码问题解决. 正文: 我们都知道,一般情况下使用post请求是不会出现中文乱码的.可是在使用httpclient发送post请求报文含中文 ...
- ajax如何传超长字符串_解决ajax超长字符串、中文乱码问题
在最近的项目测试中发现通过ajax发送超长参数时遇到这个脚本错误: 系统找不到指定资源 the system cannot locate the resource specified 意思是参数太长, ...
- php截取字符串,无乱码
今天面试,有一道题,要求截取中文字符无乱码. 当时因为要赶去另一家去面试,没有仔细分析. 虽然现在供职的这家公司b2c项目正在用,因为当时赶项目,是网上拿来直接用的. 回来以后再重新整理了一下. 代码 ...
- [代码积累]解决HL7协议、TCP/IP通讯、16进制转字符串,中文乱码的问题。
最近在做一个流水线的接口,连接的是日立生化和雅培化学发光.流水线软件提供商提供了基于HL7的通讯协议,其要求发发送完整的病人信息. 之前和迈瑞等一些国产仪器做LIS接口时,他们提供的通讯方案,也是只支 ...
- java判断字符串是中文乱码_java 检测字符串中文乱码
1.检测是否为乱码 public static booleanisMessyCode(String strName) { Pattern p= Pattern.compile("\\s*|\ ...
- php截取字符串,带中文,多余的省略号代替
function subtext($text, $length) {if(mb_strlen($text, 'utf8') > $length) {return mb_substr($text, ...
最新文章
- 华为计算平台MDC810发布量产
- 电视游戏会是未来客厅娱乐的主角吗?
- JavaScript语言基础3
- 【AWSL】之Linux管理(RPM)程序
- CentOS6.5 常用命令
- (1)触发器systemverilog与VHDL编码
- 2018 腾讯功能游戏开发者赛事火热开启
- 中国远程医疗行业发展前景预测和投资规划分析报告2022-2027年
- 南阳oj入门题-cigarettes
- Simpson积分应用
- Weka package manager 出错的解决办法
- vgg16构造模型图(转)
- 阿里云settings.xml配置
- 什么是VR全景相机?
- JVM - 双亲委派
- SQL常用的操作语句
- Vue li始终前面有黑点
- 12个基本的在线设计竞赛目录
- 操作系统第一章 --导论
- ps---融入环境调色技巧步骤-----去除扣除图的白边