php數(shù)據(jù)庫gbk亂碼 php怎么解決亂碼

mysql與php文件選擇gbk編碼時,寫入數(shù)據(jù)庫出現(xiàn)亂碼

你要確定你的頁面也是GBK~~

創(chuàng)新互聯(lián)服務(wù)項目包括珙縣網(wǎng)站建設(shè)、珙縣網(wǎng)站制作、珙縣網(wǎng)頁制作以及珙縣網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,珙縣網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到珙縣省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

如果不是的話~~強制到MYSQL的字符編碼

如果你用非OO的mysqli

那么就是執(zhí)行SQL語句

mysqli("Set Names 'GBK'");

最保險在連接數(shù)據(jù)庫后~就直接調(diào)用下

php數(shù)據(jù)庫顯示亂碼~~~怎么辦~~~

這個可能是你在安裝環(huán)境的時候出現(xiàn)了問題,在安裝mysql的時候,數(shù)據(jù)庫默認的不是gb2312,是西歐字符,建議你重新安裝數(shù)據(jù)庫,或是使用wampsever集成安裝環(huán)境,默認數(shù)據(jù)庫是utf8的,只要你建的數(shù)據(jù)庫整理為utf8

網(wǎng)頁文件也保存為utf8的

(不要bom頭的那種)以后寫php就很少出現(xiàn)問題啦。要是在php文件的最上面一行再加上這么一句代碼,?php

header("Content-Type:text/html;

charset=utf-8");?,那出現(xiàn)問題的幾率就更小了。

php頁面解決亂碼問題

1、文件編碼:指的是頁面文件(.html,.php等)本身是以何種編碼來保存的。記事本和Dreamweaver在打開頁面時候會自動識別文件編碼因而不太會出問題。而ZendStudio卻不會自動識別編碼,它只會根據(jù)首選項的配置固定以某種編碼打開文件,如果工作時候一不注意,用錯誤編碼打開文件,做了修改之后一保存,亂碼就出現(xiàn)了(我深有體會)。

2、頁面申明編碼:在HTML代碼HEAD里面,可以用meta http-equiv="Content-Type" content="text/html; charset="XXX" /來告訴瀏覽器網(wǎng)頁采用了什么編碼,目前中文網(wǎng)站開發(fā)中XXX主要用的是GB2312和UTF-8兩種編碼。

3、數(shù)據(jù)庫連接編碼:指的是進行數(shù)據(jù)庫操作時候以哪種編碼與數(shù)據(jù)庫傳輸數(shù)據(jù),這里需要注意的是不要與數(shù)據(jù)庫本身的編碼混淆,比如MySQL內(nèi)部默認是latin1編碼,也就是說Mysql是以latin1編碼來存儲數(shù)據(jù),以其他編碼傳輸給Mysql的數(shù)據(jù)會被轉(zhuǎn)換成latin1編碼。

知道了WEB開發(fā)中哪些地方涉及到了編碼,也就知道了PHP頁面亂碼產(chǎn)生的原因:上述3項編碼設(shè)置不一致,由于各種編碼絕大部分是兼容ASCII的,所以英文符號不會出現(xiàn),中文就倒霉了。下面是一些常見的錯誤情況與解決:

1、數(shù)據(jù)庫采用UTF8編碼,而頁面申明編碼是GB2312,這是最常見的產(chǎn)生亂碼的原因。這時候在PHP腳本里面直接SELECT數(shù)據(jù)出來的就是PHP頁面亂碼,需要在查詢前先使用:

mysql_query("SET NAMES GBK"); 來設(shè)定MYSQL連接編碼,保證頁面申明編碼與這里設(shè)定的連接編碼一致(GBK是GB2312的擴展)。如果頁面是UTF-8編碼的話,可以用:

mysql_query("SET NAMES UTF8"); 注意是UTF8而不是一般用的UTF-8。假如頁面申明的編碼與數(shù)據(jù)庫內(nèi)部編碼一致可以不設(shè)定連接編碼。

注:事實上MYSQL的數(shù)據(jù)輸入輸出比上面講的更復(fù)雜一些,MYSQL配置文件my.ini中定義了2個默認編碼,分別是[client]里的default-character-set和[mysqld]里的default-character-set來分別設(shè)定默認時候客戶端連接和數(shù)據(jù)庫內(nèi)部所采用的編碼。我們上面指定的編碼其實是MYSQL客戶端連接服務(wù)器時候的命令行參數(shù)character_set_client,來告訴MYSQL服務(wù)器接受到的客戶端數(shù)據(jù)是什么編碼的,而不是采用默認編碼。

2、頁面申明編碼與文件本身編碼不一致,這種情況很少發(fā)生,因為如果編碼不一致美工做頁面時候在瀏覽器看到的就是亂碼了。更多時候是發(fā)布以后修改一些小BUG,以錯誤編碼打開頁面然后保存導(dǎo)致的?;蛘呤怯媚承〧TP軟件直接在線修改文件,比如CuteFTP,由于軟件編碼配置錯誤而導(dǎo)致轉(zhuǎn)換錯了編碼。

3、一些租用虛擬主機的朋友,明明上述3項編碼都設(shè)置正確了還是有PHP頁面亂碼。比方說網(wǎng)頁是GB2312編碼的,IE等瀏覽器打開卻總是識別成UTF-8,網(wǎng)頁HEAD里面已經(jīng)申明是GB2312了,手動修改瀏覽器編碼為GB2312后頁面顯示正常。產(chǎn)生原因是服務(wù)器Apache設(shè)定了服務(wù)器全局的默認編碼,在httpd.conf里面加了AddDefaultCharset UTF-8。這時候服務(wù)器會首先發(fā)送HTTP頭給瀏覽器,其優(yōu)先級比頁面里申明編碼高,自然瀏覽器就識別錯了。解決辦法有2個,請管理員在配置文件自己的虛機里加上一條AddDefaultCharset GB2312來覆蓋全局配置,或者在自己目錄的.htaccess里配置。

高手求救,php調(diào)用mysql數(shù)據(jù)庫不能顯示中文呈亂碼?

以前的國外主機用的Mysql是4.x系列的,感覺還比較好,都無論GBK和UTF-8都沒有亂碼,沒想到新的主機的Mysql是5.0版本的,導(dǎo)入數(shù)據(jù)后,用Php讀出來全是問號,亂碼一片,記得我以前也曾經(jīng)有過一次切換出現(xiàn)亂碼的經(jīng)驗,原因肯定是Mysql版本之間的差異問題。

只好查資料,發(fā)現(xiàn)了一個解決方法,就是在mysql_connect后面加一句SET

NAMES

UTF8,即可使得UTF8的數(shù)據(jù)庫消除亂碼,對于GBK的數(shù)據(jù)庫則使用SET

NAMES

GBK,代碼如下:

$mysql_mylink

=

mysql_connect($mysql_host,

$mysql_user,

$mysql_pass);

mysql_query("SET

NAMES

'GBK'");

本文題目:php數(shù)據(jù)庫gbk亂碼 php怎么解決亂碼
瀏覽路徑:http://muchs.cn/article6/ddipeog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、關(guān)鍵詞優(yōu)化微信小程序、網(wǎng)站收錄、網(wǎng)站設(shè)計公司、虛擬主機

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司