国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

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

2024-05-04 21:49:07
字體:
來源:轉載
供稿:網友

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里配置.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 枣阳市| 九寨沟县| 英吉沙县| 余江县| 海林市| 镇安县| 炎陵县| 文水县| 抚顺市| 江达县| 甘洛县| 防城港市| 阆中市| 惠来县| 阳西县| 兴宁市| 府谷县| 沙田区| 定西市| 广宁县| 瑞丽市| 绵竹市| 保亭| 凌海市| 天气| 营口市| 峨山| 康马县| 湖南省| 理塘县| 丰县| 石家庄市| 长宁县| 寻甸| 三台县| 敖汉旗| 承德市| 当涂县| 博爱县| 汕头市| 措勤县|