php截取頭一個中文亂碼的解決方法:1、建立一個PHP範例檔;2、設定「charset=utf-8」編碼;3、透過「function str($str='',$ len=0){...}”方法截取即可。
本文操作環境:Windows7系統、PHP7.4版、DELL G3電腦
php怎麼截取頭一個中文亂碼?
php解決中文截取亂碼問題
針對截取字串出現中文亂碼問題,網路上有很多介紹,也有很多函數,但筆者看著網路上的函數,總覺得有點彆扭,
所以自己動手寫了一個防止截取字串時出現中文亂碼的函數。
實現的原理還是比較簡單,主要是利用ASCII編碼和中文編碼的二進位範圍不一致而把它們區分開來,然後,透過substr()截取字串的函數實現的。
下面給出我寫的程式碼,注意:我這裡只針對utf-8編碼,其他編碼,看官可以自己手動改一下函數,以便支援其他的編碼。
<?php header('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 } } //如果要截取的个数超过了字符串的总个数,那么我们返回全部字符串,不带省略号 if($len > $count){ return $str; }else{ return substr($str,0,$i).'...'; } }
以上程式碼的實作就是利用單字元的ASCII碼小於0x80。至於要跳過幾個字節,這要看具體是什麼編碼。
有什麼錯誤,還望指出。
推薦學習:《PHP影片教學》
以上是php怎麼截取頭一個中文亂碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!