php substr函數出現亂碼是因為中文UTF-8編碼,每個漢字佔3字節,而GB2312佔2字節,英文佔1字節,截取位數不準確導致亂碼,其解決辦法就是使用mb_substr函數即可。
推薦:《PHP影片教學》
php 解決截取字串亂碼問題
問題
在日常的開發中,常常會用到字串截取的功能,通常使用的函數是substr()。下面是範例:
<?php $rest = substr ("abcdef", 1); // returns "bcdef" $rest = substr ("abcdef", 1, 3); // returns "bcd" ?>
使用substr函數時遇到中文字元容易出現亂碼。這是因為中文UTF-8編碼,每個漢字佔3字節,而GB2312佔2字節,英文佔1字節,截取位數不準確,substr()硬生生地將一個中文字符“鋸”成兩半,造成斷開的字符會把其後的拉過來一起做一個字,所以出現了PHP substr中文亂碼。
解決方法
可以使用mb_substr()函數。下面是範例:
echo mb_substr("php中文字符encode",0,4,"utf-8");
以上是如何解決substr php 亂碼問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!