PHP文件本身编码没有问题,这个文件没有连接数据库,所以不存在数据库编码问题。
就是如下一段简单的代码:
$str = '某人咋某天进行了一次体能训练!';
$str1 = '啊';
$str2 = '*';
$a = str_ireplace($str1, $str2, $str);
echo $a;
echo '
';
$b = substr_replace($str, $str2, 20, 2);(问题出在这里,浏览器中出现的效果是:某人咋某天进��*��一次体能训练!)
echo $b;
echo '
';
找到问题根源了,utf-8编码,一个中文字符占用3个长度。
同一个PHP文件中用substr_replace函数时出现乱码问题,用str_ireplace函数时正常,究竟问题出在哪儿了
答案:3 悬赏:0
解决时间 2021-02-17 01:37
- 提问者网友:小姐请专情
- 2021-02-16 00:41
最佳答案
- 二级知识专家网友:而你却相形见绌
- 2021-02-16 02:03
用chr()函数返回值检测下是不是中文的是中文并且是utf-8的话截取三个字节不是utf-8的话截取两个英文截取一个
全部回答
- 1楼网友:旧事诱惑
- 2021-02-16 02:37
需要从写 该函数
if($length && strlen($string) > $length) {
//截断字符
$wordscut = '';
if(strtolower($encoding) == 'utf-8') {
//utf8编码
$n = 0;
$tn = 0;
$noc = 0;
while ($n < strlen($string)) {
$t = ord($string[$n]);
if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
$tn = 1;
$n++;
$noc++;
} elseif(194 <= $t && $t <= 223) {
$tn = 2;
$n += 2;
$noc += 2;
} elseif(224 <= $t && $t < 239) {
$tn = 3;
$n += 3;
$noc += 2;
} elseif(240 <= $t && $t <= 247) {
$tn = 4;
$n += 4;
$noc += 2;
} elseif(248 <= $t && $t <= 251) {
$tn = 5;
$n += 5;
$noc += 2;
} elseif($t == 252 || $t == 253) {
$tn = 6;
$n += 6;
$noc += 2;
} else {
$n++;
}
if ($noc >= $length) {
break;
}
}
if ($noc > $length) {
$n -= $tn;
}
$wordscut = substr($string, 0, $n);
} else {
for($i = 0; $i < $length - 1; $i++) {
if(ord($string[$i]) > 127) {
$wordscut .= $string[$i].$string[$i + 1];
$i++;
} else {
$wordscut .= $string[$i];
}
}
}
$string = $wordscut;
}
return trim($string);
}
这个函数 就不会有乱码了
- 2楼网友:时光不老我们不分离
- 2021-02-16 02:32
建议使用mb_substr和mb_strcut。具体差别可以看下资料。
另外如果实际应用的话最好在截取之前过滤一下标签(strip_tags)。否则有的时候会截断标签。
即使自定义的function的话基本上也都是用的mb_substr或者mb_strcut
再看看别人怎么说的。
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯