php+mysql的utf-8中文亂碼問題的解決方法

成都創(chuàng)新互聯(lián)主營中站網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,App定制開發(fā),中站h5成都小程序開發(fā)搭建,中站網(wǎng)站營銷推廣歡迎中站等地區(qū)企業(yè)咨詢
問題匯總:
1.mysql數(shù)據(jù)庫默認(rèn)的編碼是utf8,如果這種編碼與你的PHP網(wǎng)頁不一致,可能就會(huì)造成MYSQL亂碼.
2.MYSQL中創(chuàng)建表時(shí)會(huì)讓你選擇一種編碼,如果這種編碼與你的網(wǎng)頁編碼不一致,也可能造成MYSQL亂碼.
3.MYSQL創(chuàng)建表時(shí)添加字段是可以選擇編碼的,如果這種編碼與你的網(wǎng)頁編碼不一致,也可能造成MYSQL亂碼.
4.用戶提交頁面的編碼與顯示數(shù)據(jù)的頁面編碼不一致,就肯定會(huì)造成PHP頁面亂碼.
5.如用戶輸入資料的頁面是big5碼, 顯示用戶輸入的頁面卻是gb2312,這種100%會(huì)造成PHP頁面亂碼.
6.PHP頁面字符集不正確.
7.PHP連接MYSQL數(shù)據(jù)庫語句指定的編碼不正確.
使用mysql+php產(chǎn)生亂碼的原因都了解得很清楚了,那么解決就不困難了.
針對不同問題的解決方法:
1.mysql數(shù)據(jù)庫默認(rèn)的編碼是utf8,如果這種編碼與你的PHP網(wǎng)頁不一致,可能就會(huì)造成MYSQL亂碼.
修改數(shù)據(jù)庫編碼,如果是數(shù)據(jù)庫編碼不正確,可以在phpmyadmin 執(zhí)行如下命令:
Alter DATABASE 'test' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin
以上命令就是將test數(shù)據(jù)庫的編碼設(shè)為utf8.
2.MYSQL中創(chuàng)建表時(shí)會(huì)讓你選擇一種編碼,如果這種編碼與你的網(wǎng)頁編碼不一致,也可能造成MYSQL亂碼.
修改表的編碼:
Alter TABLE 'category' DEFAULT CHARACTER SET utf8 COLLATE utf8_bin
以上命令就是將一個(gè)表category的編碼改為utf8.
3.MYSQL創(chuàng)建表時(shí)添加字段是可以選擇編碼的,如果這種編碼與你的網(wǎng)頁編碼不一致,也可能造成MYSQL亂碼.
修改字段的編碼:
Alter TABLE 'test' CHANGE 'dd' 'dd' VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL
以上命令就是將test表中 dd的字段編碼改為utf8.
4.用戶提交頁面的編碼與顯示數(shù)據(jù)的頁面編碼不一致,就肯定會(huì)造成PHP頁面亂碼.
如果是這種情況容易解決,只需檢查下頁面,修改源文件的charset即可.
5.如用戶輸入資料的頁面是big5碼, 顯示用戶輸入的頁面卻是gb2312,這種100%會(huì)造成PHP頁面亂碼.
這種情況也是修改頁面charset即可.
6.PHP頁面字符集不正確.
為了避免PHP頁面亂碼的發(fā)生,PHP頁面開始第一句
header("content-type:text/html; charset=utf-8");
//強(qiáng)行指定頁面的編碼,以避免亂碼
7.PHP連接MYSQL數(shù)據(jù)庫語句指定的編碼不正確.
在連接數(shù)據(jù)庫的語句中.
mysql_connect('localhost','user','password');
mysql_select_db('my_db');
mysql_query("set names 'utf8'"); //select 數(shù)據(jù)庫之后加多這一句
從你的截圖來看應(yīng)該數(shù)據(jù)庫讀取的數(shù)據(jù)沒有問題,問題有可能出在你的前臺(tái)顯示上面,在頁面輸入的時(shí)候是不是對應(yīng)的字段取得有問題。或許你去的東西根本就沒有存在于讀出的數(shù)組中。
也許是數(shù)據(jù)庫的問題,我也遇到過,我用的是wampserver,界面的工具,直接點(diǎn)鼠標(biāo)就可能建成mysql數(shù)據(jù)庫,建成后導(dǎo)入數(shù)據(jù),查詢數(shù)據(jù)庫返回面而的是亂碼,我遇到的情況是這樣的:
1、建庫用gbk,如圖。
2、導(dǎo)入表及數(shù)據(jù)時(shí),默認(rèn)是utf,此處要改成gbk就不是亂碼了,如第圖底頁面,如果是默認(rèn)的或是其它的字符集,能導(dǎo)入成功但是亂碼。另外直接把sql粘貼到sql窗口,也不是亂碼。
希望能幫到你,呵呵~
access的中文版默認(rèn)是GBK格式的,是無法改變字符類型的,所以用php讀取的時(shí)候會(huì)亂碼。
解決方法是:使用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ù)庫的編碼是符合數(shù)據(jù)庫需要的,所以我們還要制作一個(gè)從UTF-8轉(zhuǎn)向GBK的函數(shù):
function dec($c){return iconv('utf-8','gb2312',$c);}
制作好了轉(zhuǎn)碼函數(shù),接下就是正常使用了。在從數(shù)據(jù)庫里面調(diào)數(shù)據(jù)顯示在頁面的時(shí)候使用enc()函數(shù),從頁面提交數(shù)據(jù)到數(shù)據(jù)庫時(shí)使用dec()函數(shù),這樣就可以很好的解決PHP使用UTF-8編碼,ACCESS使用系統(tǒng)默認(rèn)編碼的問題了。
要解決亂碼首先需要知道出現(xiàn)亂碼的原因:
一、PHP+MySQL出現(xiàn)中文亂碼的原因。
1. MYSQL數(shù)據(jù)庫的編碼是utf8,與PHP網(wǎng)頁的編碼格式不一致,就會(huì)造成MYSQL中的中文亂碼。
2. 使用MYSQL中創(chuàng)建表、或者選擇字段時(shí)設(shè)置的類型不是utf8,而網(wǎng)頁編碼不是utf8,也可能造成MYSQL中文亂碼.
3. PHP頁面的字符集與數(shù)據(jù)庫的編碼不一致。
4. PHP連接MYSQL數(shù)據(jù)庫,操作是設(shè)定的語句指定的編碼和頁面編碼,PHP頁面編碼不一致。
5. 用戶提交的HTML頁面編碼,和顯示數(shù)據(jù)的頁面編碼不一致 ,就肯定會(huì)造成PHP頁面亂碼.
二、解決中文亂碼:
1. 網(wǎng)頁編碼設(shè)置。一般在HTML代碼中的文件頭html中加入屬性:
meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″
保證,網(wǎng)頁是"utf-8"編碼。
2. PHP代碼設(shè)置。在php代碼的開始部分加入以下代碼:
header(”Content-type: text/html;charset=utf-8″);
且要求保存的文件編碼方式是utf-8,這樣就保證了該文件也是utf-8編碼。
3. 數(shù)據(jù)庫中表的字段中存儲(chǔ)中文的部分,要設(shè)置為utf8_general_ci類型。
4.PHP在連接數(shù)據(jù)庫操作時(shí),要設(shè)置操作的字段類型為utf8,設(shè)置方法如下:
mysql_connect(’localhost’,'user’,'password’);mysql_select_db(’db’);mysql_query(”set names utf8;”); //**設(shè)置字符集***
可能需要修改數(shù)據(jù)庫的配置
一般情況下我們在設(shè)計(jì)數(shù)據(jù)庫的時(shí)候都會(huì)事先確定好要用的字符集,但當(dāng)我們要使用以前的數(shù)據(jù)的時(shí)候,可能會(huì)遇到字符集不同的問題,字符集的修改不能通過alert database charest set *來直接修改,這樣只是影響以后的數(shù)據(jù),對已有的數(shù)據(jù)沒有用,那怎么辦那
我們模擬講latin1字符集的數(shù)據(jù)庫修改成GBK的字符集,
1,導(dǎo)出表結(jié)構(gòu):
mysqldump -uroot -p --default -character-set = gbk -d databasenamecreatetab.sql
-default-character-set=gbk 表示設(shè)置上面字符集連接 -d表示只導(dǎo)出表結(jié)構(gòu)
2,手工修改createtab.sql中表結(jié)構(gòu)定義中的字符集為新的字符集。
3,確保記錄不在更新,導(dǎo)出所有記錄
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-chareacter-set=latina
databasenamedate.sql
--quick 該選項(xiàng)用于轉(zhuǎn)存儲(chǔ)大的表,--extended-insert 可以使轉(zhuǎn)存文件更小,重載的時(shí)候加快速度,
--no-create-info不寫重新創(chuàng)建每個(gè)轉(zhuǎn)存儲(chǔ)表的create table 語句,--default-character-set=latin1按照原有的字符集導(dǎo)出所有數(shù)據(jù),這樣導(dǎo)出的文件中,所有的中文都是可見的,保證不會(huì)出項(xiàng)亂碼,
4,打開data.sql 將set names lation1修改為set names gbk;
5,使用新的字符集創(chuàng)建數(shù)據(jù)庫,
create database databasename default charset gbk;
6,創(chuàng)建表,執(zhí)行createtab.sql
mysql -uroot -p databasename createtab.sql
7,導(dǎo)入數(shù)據(jù),執(zhí)行data.sql,
mysql -uroot -p databasename data.sql
參考上面的方法試驗(yàn)下!~
網(wǎng)站欄目:php數(shù)據(jù)庫解碼 php源碼解析
網(wǎng)站路徑:http://chinadenli.net/article16/hipddg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、響應(yīng)式網(wǎng)站、靜態(tài)網(wǎng)站、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站營銷、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)