標籤:簡單 解決 echo 網上 text ... 擷取 ascii 其他
針對截取字串出現中文亂碼問題,網上有很多介紹,也有很多函數,但筆者看著網上的函數,總感覺有點彆扭,
所以自己動手寫了一個防止截取字串時出現中文亂碼的函數。
實現的原理還是比較簡單,主要是利用ASCII編碼和中文編碼的二進位範圍不一致而把它們區分開來,然後,通過substr()截取字串的函數實現的。
下面給出我寫的代碼,注意:我這裡只針對utf-8編碼,其他編碼,看官可以自己手動改一下函數,以便支援其他的編碼。
<?phpheader(‘content-type:text/html;charset=utf-8;‘);$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 } } return substr($str,0,$i).‘...‘;}echo str($str,12);
以上代碼的實現就是利用單位元組字元的ASCII碼小於0x80。至於要跳過幾個位元組,這要看具體是什麼編碼。
有什麼錯誤,還望指出。
php解決中文截取亂碼問題