PHP輸出中文亂碼解決:編碼終結者
學習PHP之初,根本就沒有意識到過有編碼那回事兒,隨著對中文的輸出越來越多,遇到輸出亂碼的情況也就更加普遍了。最早我們懷疑是數據庫編碼的問題,於是在PHP代碼中的解決的辦法是:
mysql_query("SET NAMES UTF8");
但這樣做了後,網頁顯示的仍然是亂碼,於是有修改網頁頭部信息:
header(‘Content-type:text/html;charset=UTF8‘);
順便還找到條其他命令,也不知道能起到什麽作用,反正遇到亂碼的時候就把它加進去,解決問題即可:
declare(encoding=‘UTF-8‘);
還有一種情況,是文件編碼與輸出編碼沖突,例如PHP文件編碼是ANSI
問題到此,基本能夠解決顯示亂碼的現象了!
但是,我覺得不應該就此結束!
我大膽地思考這個問題,然後百度了一下“PHP轉換字符串編碼”,果然有對應的函數可以解決這個問題!
那就是:
mb_detect_encoding — 檢測字符的編碼,和mb_convert_encoding — 轉換字符的編碼,這兩個函數。
關於這兩個函數的用法,請各位自己去搜索吧,PHP手冊裏面也很詳盡,我就不在此占用篇幅了。
另外還有個函數:iconv,它的效率比mb_convert_encoding 高,但功能沒mb_convert_encoding 好,了解後你自己取舍吧!
但,經過本人研究了一兩天,貌似這兩個函數並沒如我所願地把字符串隨意地轉換成GBK,GB2312,UTF-8的編碼,也許是我的“打開方式不對”?總之,方法找到了,只是用法還沒掌握,也就是時間的問題而已啦。
所以,在此分享本人的經驗,希望能幫小白清除這方面的疑惑,也歡迎大牛在此補充指教哈!
本文出自 “七彩極” 博客,請務必保留此出處http://qicaiji.blog.51cto.com/1158325/1959291
PHP輸出中文亂碼解決:編碼終結者