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");//Vevb.com
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里配置.
新聞熱點
疑難解答