access的中文版默認(rèn)是GBK格式的,是無(wú)法改變字符類型的,所以用php讀取的時(shí)候會(huì)亂碼。
網(wǎng)站建設(shè)公司,為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì)及定制網(wǎng)站建設(shè)服務(wù),專注于成都企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁(yè)制作,對(duì)木包裝箱等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。專業(yè)網(wǎng)站設(shè)計(jì),網(wǎng)站優(yōu)化推廣哪家好,專業(yè)seo優(yōu)化優(yōu)化,H5建站,響應(yīng)式網(wǎng)站。
解決方法是:使用iconv轉(zhuǎn)換
一、使用 iconv函數(shù)制作一個(gè)轉(zhuǎn)碼的自定義從GBK轉(zhuǎn)到UTF-8的函數(shù),如以下代碼:
function enc($c){return iconv('gbk','utf-8',$c);}
二、為了寫入數(shù)據(jù)庫(kù)的編碼是符合數(shù)據(jù)庫(kù)需要的,所以我們還要制作一個(gè)從UTF-8轉(zhuǎn)向GBK的函數(shù):
function dec($c){return iconv('utf-8','gb2312',$c);}
制作好了轉(zhuǎn)碼函數(shù),接下就是正常使用了。在從數(shù)據(jù)庫(kù)里面調(diào)數(shù)據(jù)顯示在頁(yè)面的時(shí)候使用enc()函數(shù),從頁(yè)面提交數(shù)據(jù)到數(shù)據(jù)庫(kù)時(shí)使用dec()函數(shù),這樣就可以很好的解決PHP使用UTF-8編碼,ACCESS使用系統(tǒng)默認(rèn)編碼的問(wèn)題了。
打算切換某個(gè)網(wǎng)站的主機(jī),沒(méi)想到遇到Php和Mysql中文亂碼的問(wèn)題。
以前的國(guó)外主機(jī)用的Mysql是4.x系列的,感覺(jué)還比較好,都無(wú)論GBK和UTF-8都沒(méi)有亂碼,沒(méi)想到新的主機(jī)的Mysql是5.0版本的,導(dǎo)入數(shù)據(jù)后,用Php讀出來(lái)全是問(wèn)號(hào),亂碼一片,記得我以前也曾經(jīng)有過(guò)一次切換出現(xiàn)亂碼的經(jīng)驗(yàn),原因肯定是Mysql版本之間的差異問(wèn)題。
只好查資料,發(fā)現(xiàn)了一個(gè)解決方法,就是在mysql_connect后面加一句SET
NAMES
UTF8,即可使得UTF8的數(shù)據(jù)庫(kù)消除亂碼,對(duì)于GBK的數(shù)據(jù)庫(kù)則使用SET
NAMES
GBK,代碼如下:
$mysql_mylink
=
mysql_connect($mysql_host,
$mysql_user,
$mysql_pass);
mysql_query("SET
NAMES
'GBK'");
以上就是小編為大家?guī)?lái)的PHP讀MYSQL中文亂碼的快速解決方法的全部?jī)?nèi)容了,希望對(duì)大家有所幫助,多多支持腳本之家~
從后臺(tái)讀取數(shù)據(jù)時(shí),通常會(huì)出現(xiàn)亂碼情況,比如“漢字”變成“?”等,造成這種情況的原因通常是編碼設(shè)置不對(duì),解決方法如下:
第一種方法:在php中添加如下代碼,將編碼格式設(shè)為“utf-8”,代碼如下:
header("Content-Type: text/html; charset=UTF-8");
第二種方法:在php中添加另外一行代碼,同樣用來(lái)轉(zhuǎn)碼,代碼如下:
$conn = mysqli_connect($servername, $username, $password, $mysqlname);
$conn-query("SET NAMES utf8");
該種情況是先創(chuàng)建鏈接,之后再轉(zhuǎn)碼。
另外,在使用數(shù)據(jù)庫(kù)時(shí),直接手動(dòng)(非代碼)建表,通常會(huì)在表中輸入漢字時(shí),瀏覽時(shí)無(wú)法顯示或顯示為“?”,造成這種情況的原因也是編碼問(wèn)題,解決方案如下:
在建表或建庫(kù)時(shí),表和庫(kù)的編碼格式一定要統(tǒng)一,設(shè)置成:“utf8_general_ci”,如下圖:
其實(shí),只要注意文件編寫的時(shí)候編碼、數(shù)據(jù)庫(kù)的編碼一般就不會(huì)有這個(gè)問(wèn)題的,但是,比如你用DW(dwcs4貌似沒(méi)有這個(gè)現(xiàn)象)打開文件,它會(huì)以默認(rèn)的編碼讀取,一旦你保存了,那就完了,用EditPlus打開之后,右下角有編碼提示,如果發(fā)現(xiàn)不對(duì),另存為,覆蓋一下,就可以了