溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php如何截取頭一個(gè)中文亂碼

發(fā)布時(shí)間:2021-12-02 11:03:29 來(lái)源:億速云 閱讀:149 作者:iii 欄目:編程語(yǔ)言

這篇文章主要講解了“php如何截取頭一個(gè)中文亂碼”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“php如何截取頭一個(gè)中文亂碼”吧!

php截取頭一個(gè)中文亂碼的解決辦法:1、創(chuàng)建一個(gè)PHP示例文件;2、設(shè)置“charset=utf-8”編碼;3、通過(guò)“function str($str='',$len=0){...}”方法截取即可。

php如何截取頭一個(gè)中文亂碼

本文操作環(huán)境:Windows7系統(tǒng)、PHP7.4版、DELL G3電腦

php怎么截取頭一個(gè)中文亂碼?

php解決中文截取亂碼問(wèn)題

  針對(duì)截取字符串出現(xiàn)中文亂碼問(wèn)題,網(wǎng)上有很多介紹,也有很多函數(shù),但筆者看著網(wǎng)上的函數(shù),總感覺(jué)有點(diǎn)別扭,

  所以自己動(dòng)手寫了一個(gè)防止截取字符串時(shí)出現(xiàn)中文亂碼的函數(shù)。

  實(shí)現(xiàn)的原理還是比較簡(jiǎn)單,主要是利用ASCII編碼和中文編碼的二進(jìn)制范圍不一致而把它們區(qū)分開(kāi)來(lái),然后,通過(guò)substr()截取字符串的函數(shù)實(shí)現(xiàn)的。

  下面給出我寫的代碼,注意:我這里只針對(duì)utf-8編碼,其他編碼,看官可以自己手動(dòng)改一下函數(shù),以便支持其他的編碼。

<?php
header('content-type:text/html;charset=utf-8;');
$str = '利要a-符e:r ttnx節(jié)小-子s區(qū)。vh;peh。例t來(lái)個(gè)oe體字n代gb節(jié)看t通c eu是的soS至什tna過(guò)碼 t;Ie看C實(shí)e/,字le A來(lái)具8y么a)n=于ndg是r于 0tmt現(xiàn)碼 e0ssf8單下s(uo別e的以ieh過(guò)aatx和t接要u幾這看 nsw Ihrr用字 mgtts上就eg cAei的nwo碼e跳h,t編';
/*
*在某篇文章中截取一段字符串,多余的用省略號(hào)...表示,并且防止中文亂碼
*$param1 string要截取的字符串 $str  注意:這里是utf-8編碼
*$param2 int截取字符串的長(zhǎng)度 $len  
*返回值 成功返回所要截取的字符串,失敗為空
*/
function str($str='',$len=0){
    //檢查參數(shù)
    if(!is_string($str) || !is_int($len)){
        return '';
    }
    $length = strlen($str);
    if($length <= 0 ){
        return '';
    }
    if($len>=$length){
        return $str;
    }
    //初始化,統(tǒng)計(jì)字符串的個(gè)數(shù),
    $count = 0;
    for($i=0;$i<$length;$i++){
        //達(dá)到個(gè)數(shù)跳出循環(huán),$i即為要截取的長(zhǎng)度
        if($count == $len){
            break;
        }
        $count++;
        //ord函數(shù)是獲取字符串的ASCII編碼,大于等于十六進(jìn)制0x80的字符串即為中文字符串
        if(ord($str{$i}) >= 0x80){
            $i +=2;//中文編碼的字符串的長(zhǎng)度再加2
        }
    }
    //如果要截取的個(gè)數(shù)超過(guò)了字符串的總個(gè)數(shù),那么我們返回全部字符串,不帶省略號(hào)
    if($len > $count){
        return $str;
    }else{
        return substr($str,0,$i).'...';
    }
}

感謝各位的閱讀,以上就是“php如何截取頭一個(gè)中文亂碼”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)php如何截取頭一個(gè)中文亂碼這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI