色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php自動獲取字符串編碼函數mb_detect_encoding

當在php中使用mb_detect_encoding函數進行編碼識別時,很多人都碰到過識別編碼有誤的問題,例如對與GB2312和UTF- 8,或者UTF-8和GBK(這里主要是對于cp936的判斷),網上說是由于字符短是,mb_detect_encoding會出現誤判。
例如:
復制代碼 代碼如下:
$encode = mb_detect_encoding($keytitle, array("ASCII",'UTF-8′,"GB2312′,"GBK",'BIG5′));
if ($encode == “UTF-8″){
$keytitle = iconv("UTF-8″,"GBK",$keytitle);
}

這段代碼的作用是檢測字符串的編碼是否UTF-8,是的話就轉換為GBK。
可是當 $keytitle = “%D0%BE%C6%AC”;時。檢測結果卻是UTF-8.這個bug其實不算是bug,寫程序時也不應當過于依賴mb_detect_encoding,當字符串較短時,檢測結果產生偏差的可能性很大。
怎么解決呢,我的辦法是:
復制代碼 代碼如下:
$encode = mb_detect_encoding($keytitle, array('ASCII','GB2312′,'GBK','UTF-8');

三個參數分別是:被檢測的輸入變量、編碼方式的檢測順序(一旦為真,后面自動忽略)、strict模式
對編碼檢測的順序進行調整,將最大可能性放在前面,這樣減少被錯誤轉換的機會。
一般要先排gb2312,當有GBK和UTF-8時,需要將常用的排列到前面。

php技術php自動獲取字符串編碼函數mb_detect_encoding,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 当雄县| 松溪县| 吴川市| 甘南县| 溆浦县| 东兰县| 丹江口市| 凤山市| 虹口区| 曲阜市| 兴仁县| 清涧县| 舒兰市| 拜泉县| 新宁县| 横山县| 阿巴嘎旗| 海安县| 延边| 南召县| 赤城县| 巴彦淖尔市| 阿坝县| 财经| 葵青区| 连城县| 容城县| 长垣县| 东城区| 米泉市| 西贡区| 灵宝市| 溧水县| 招远市| 石屏县| 南木林县| 白银市| 萍乡市| 闽清县| 衡阳县| 东明县|