|
老聲長談,著是困惑很多人的問題,如果處理不好,都是亂碼,說這些話并不是我對編碼很精通,只是在這方面是得留神,自己總結了一點小經驗(容易出現亂碼的地方有php文件里面 ,數據庫里面 存儲 的編碼 ,頁面顯示 ,數據傳輸 ):
1.在建數據庫的時候,尤其是用phpMyAdmin與MYSQL打交道時候,一般都是utf-8,字段為 utf8_general_ci
數據庫的設置:
在my.ini文件中查找:
[mysql]
default-character-set = utf8
[mysqld]
default-character-set = utf8
init_connect = 'SET NAMES utf8 '
全部設置為utf8
保存,重新啟動mysql服務
2.在與數據打交道的時候mysql_query("set names 'utf8'");注意是:utf8,不是 utf-8
3.php的文件默認的編碼是ANSI ,需要轉換為UTF-8 ,至于怎么轉換editplus就有這樣的功能,“另存為”的時候有選擇編碼UTF-8 ,注意:不能選擇:UTF-8 + BOM,如果選擇這個了 ,你在處理session的時候就會出現問題,所以一定要注意.還有有的人在eclipse,Myeclipse,ZendStudio里面開發,eclipse里面默認的是ISO-8859-1,需要在“窗口 ”->“首選項 ”打開“首選項”窗口,在左側“常規 ”->“工作空間 ”,在“文本文件編碼 ”里面設置默認的編碼為utf-8
4.就是php文件里面要說明:如<meta http-equiv="Content-Type" Content="text/html;charset=utf-8">
或者
復制代碼 代碼如下:
<?php header('Content-Type:text/html;charset=utf-8');?>
5.還有就是處理中文等雙字節的時候也有可能出現亂碼,php里面可以采用的有iconv,mb_convert_encoding來處理雙字節,其余的可以參考php幫助手冊
6.在補充一點(遺漏的一點),在你的程序里面你要知道數據之間的傳遞也有可能存在編碼問題的,但是你又不知道傳遞過來的數據是采用的什么編碼,在php里面提供了方法來處理的,下面是自己寫的一個簡單方法,可以參考一下
復制代碼 代碼如下:
//編碼轉換
function display_fileencoding($filename)
{
if(extension_loaded("mbstring"))
{
$code=mb_detect_encoding($filename);//檢測字符串編碼
$filename=mb_convert_encoding($filename,"UTF-8",$code);//將編碼$code轉換為utf-8編碼
return $filename;
}
else
die("請檢查系統是否正確安裝配置mbstring");
}
要確保mbstring在你的php.ini中啟用
7.保證以上幾處編碼一致就可以了!!數據庫,網頁輸出都不會出現亂碼了,如有不對的,請留言指出!!
php技術:PHP utf-8編碼問題,utf8編碼,數據庫亂碼,頁面顯示輸出亂碼,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。