程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP+MYSQL 出現亂碼問號的解決方法

PHP+MYSQL 出現亂碼問號的解決方法

編輯:關於PHP編程

php與mysql密碼多半與php是沒有任何關系了,這個我們只要把頁面與mysql編碼進行處理即可解決亂碼問題,亂碼也只是中文會亂碼了。

使用PHP+MYSQL時遇到過字符亂問題,解決方法:

在mysql_connect後面加一句SET NAMES UTF8,即可使得UTF8的數據庫消除亂碼,對於GBK的數據庫則使用SET NAMES GBK,代碼如下:

 代碼如下 復制代碼

1 $mysql_mylink = mysql_connect($mysql_host, $mysql_user, $mysql_pass);
2 mysql_query("SET NAMES 'GBK'");

數據庫字符集為utf-8

連接語句用這個
 

 代碼如下 復制代碼 1 mysql_query("SET NAMES 'UTF8'");
2 mysql_query("SET CHARACTER SET UTF8");
3 mysql_query("SET CHARACTER_SET_RESULTS=UTF8'");


下面是一些常見的錯誤情況與解決:

1、數據庫采用UTF8編碼,而頁面申明編碼是GB2312,這是最常見的產生亂碼的原因。這時候在PHP腳本裡面直接SELECT數據出來的就是亂碼,需要在查詢前先使用: mysql_query("SET NAMES GBK"); 來設定MYSQL連接編碼,保證頁面申明編碼與這裡設定的連接編碼一致(GBK是GB2312的擴展)。如果頁面是UTF-8編碼的話,可以用: mysql_query("SET NAMES UTF8");
注意是UTF8而不是一般用的UTF-8。假如頁面申明的編碼與數據庫內部編碼一致可以不設定連接編碼。

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

2、頁面申明編碼與文件本身編碼不一致,這種情況很少發生,因為如果編碼不一致美工做頁面時候在浏覽器看到的就是亂碼了。更多時候是發布以後修改一些小BUG,以錯誤編碼打開頁面然後保存導致的。或者是用某些FTP軟件直接在線修改文件,比如CuteFTP,由於軟件編碼配置錯誤而導致轉換錯了編碼。

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved