|
用phpmyadmin建立的數(shù)據(jù)庫(kù)如果你不指定編碼他默認(rèn)是latin1_swedish_ci 編碼,既瑞典語(yǔ)不區(qū)分大小寫(xiě),而我們中國(guó)做的網(wǎng)頁(yè)不是GBK就是GB2312編碼,這樣不出現(xiàn)亂碼才怪.
1,建立數(shù)據(jù)庫(kù)時(shí)指定編碼.
在此再?lài)Z叨一下常用的編碼,免的新手又迷茫:
如果你做的是簡(jiǎn)體中文網(wǎng)頁(yè),那么你在建立數(shù)據(jù)庫(kù)時(shí)用GB2312編碼,gb2312_chinese_ci.
如果你做的是繁體中文網(wǎng)頁(yè),那么你建立數(shù)據(jù)庫(kù)時(shí)要用gib5編碼, big5_chinese_ci
如果你做的網(wǎng)頁(yè)有簡(jiǎn)體也有繁體中文,那么推薦你用GBK編碼,gbk_chinese_ci . GBK包含的字碼比GB2312要多,當(dāng)然繁體也在其中.
如果你做的是多國(guó)語(yǔ)言網(wǎng)頁(yè),那么推薦你用UTF-8編碼 . mysql中有二種utf8編碼可供選擇 : utf8_unicode_ci與utf8_general_ci 筆者一般用utf8_general_ci ,關(guān)于這二種編碼的區(qū)別,請(qǐng)參考本站的另一篇文章: Mysql中校對(duì)集utf8_unicode_ci與utf8_general_ci的區(qū)別
我們用UTF-8編碼為例建立數(shù)據(jù)庫(kù)如圖:
語(yǔ)法: mysql_query("SET NAMES 'utf8'");
例如:
復(fù)制代碼 代碼如下:
$conn=mysql_connect('127.0.0.1','root','123456');
mysql_query("set names 'utf8'",$conn); //解決亂碼
mysql_select_db('test1',$conn);
一般情況下只要你做好了這二步,你的程序是不會(huì)出現(xiàn)亂碼的
二般情況:
二般情況一般出現(xiàn)的不多,多出現(xiàn)在做的程序語(yǔ)言比較多,比如有時(shí)做utf8的,有時(shí)做gb2312的,有時(shí)又要做big5的網(wǎng)頁(yè),用IDE建立的.php文件編碼和程序要顯示的編碼不同而引起的.
比如,我上次做了個(gè)gb2312的簡(jiǎn)體中文網(wǎng)頁(yè),現(xiàn)在老板又有吩咐要做個(gè)gbi5網(wǎng)頁(yè),但我的ide用的卻是gb2312的編碼
就拿我常用的IDE Dreamweaver來(lái)說(shuō)吧
如果還搞不定,那么在網(wǎng)頁(yè)頭部加一行http頭信息
header("Content-Type:text/html;charset=utf-8");
注意:在發(fā)送header頭信息時(shí)header前面不可以有任何輸出,包括空格在內(nèi).
好了寫(xiě)了這么多,快看看你的程序?qū)儆谀膫€(gè)情況引起的亂碼吧.
php技術(shù):二招解決php亂碼問(wèn)題,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。