您好,登錄后才能下訂單哦!
小編給大家分享一下如何解決php輸出中文亂碼問題,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
解決方法:1、HTML和PHP混合的頁面,需用meta標(biāo)簽或header()函數(shù)統(tǒng)一頁面編碼;2、純PHP的靜態(tài)頁面,使用header()函數(shù)將編碼設(shè)置為“utf-8”;3、使用mysql_query()來設(shè)置PHP連接mysql的編碼。
一般來說,亂碼的出現(xiàn)有2種原因,首先是由于編碼(charset)設(shè)置錯誤,導(dǎo)致瀏覽器以錯誤的編碼來解析,從而出現(xiàn)了滿屏亂七八糟的“天書”,其次是文件被以錯誤的編碼打開,然后保存,比如一個文本文件原先是GB2312編碼的,卻以UTF-8編碼打開再保存。要解決上述亂碼問題,首先需要知道開發(fā)中哪些環(huán)節(jié)涉及到了編碼:
1、文件編碼:指的是頁面文件(.html,.php等)本身是以何種編碼來保存的。記事本和Dreamweaver在打開頁面時候會自動識別文件編碼因而不太會出問題。而ZendStudio卻不會自動識別編碼,它只會根據(jù)首選項的配置固定以某種編碼打開文件,如果工作時候一不注意,用錯誤編碼打開文件,做了修改之后一保存,亂碼就出現(xiàn)了。
2、頁面申明編碼:在HTML代碼HEAD里面,可以用<meta http-equiv="Content-Type" content="text/html; charset="XXX" />(這句一定要寫在<title>XXX</title>前面,否則會導(dǎo)致頁面一片空白(僅限IE+PHP))來告訴瀏覽器網(wǎng)頁采用了什么編碼,目前中文網(wǎng)站開發(fā)中主要用的是GB2312和UTF-8兩種編碼。
3、數(shù)據(jù)庫連接編碼:指的是進(jìn)行數(shù)據(jù)庫操作時候以哪種編碼與數(shù)據(jù)庫傳輸數(shù)據(jù),這里需要注意的是不要與數(shù)據(jù)庫本身的編碼混淆,比如MySQL內(nèi)部默認(rèn)是latin1編碼,也就是說Mysql是以latin1編碼來存儲數(shù)據(jù),以其他編碼傳輸給Mysql的數(shù)據(jù)會被轉(zhuǎn)換成latin1編碼。
知道了WEB開發(fā)中哪些地方涉及到了編碼,也就知道了亂碼產(chǎn)生的原因:上述3項編碼設(shè)置不一致,由于各種編碼絕大部分是兼容ASCII的,所以英文符號不會出現(xiàn),中文就倒霉了。
php輸出中文亂碼的解決方法
第一種、HTML和PHP混合的頁面解決方案
方法一:使用<meta>標(biāo)簽
如果是HTML中嵌入PHP代碼,可以使用<meta charset="UTF-8">來解決中文亂碼問題
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>php輸出中文亂碼</title> </head> <body> <div class="demo"> <?php echo "億速云!"; ?> </div> </body> </html>
方法二:使用header()函數(shù)
如何是HTML和PHP混編,除了按照第一個方法所說的操作之外,還需要在PHP文件的最上面加入這句代碼:
<?php header("content-type:text/html;charset=utf-8"); //設(shè)置編碼 ?>
第二種、純PHP頁面的中文亂碼問題(數(shù)據(jù)是靜態(tài)的)
如果你的PHP頁面出現(xiàn)了亂碼,只需要在頁面的開始處加入下面代碼就可以了。
<?php header("content-type:text/html;charset=utf-8"); //設(shè)置編碼 ?>
第三種、PHP+Mysql中文亂碼問題
這個除了按照第三種所說的操作之外,還要在你的數(shù)據(jù)查詢/修改/增加之前加入數(shù)據(jù)庫編碼。而且,值得注意的是,這里的UTF8和之前的不一樣,中間是沒有橫線的。
<?php mysql_query('SET NAMES UTF8'); //接下來的就是查出數(shù)據(jù)或者修改,增加 ?>
如何你使用的MySQL版本在 4.1 或更高版本,可以在鏈接數(shù)據(jù)庫操作后,設(shè)置一個字符編碼,像下面這樣
注意:
在需要做數(shù)據(jù)庫操作的php程序前加的 mysql_query("set names '編碼'");編碼,一定要和php編碼一致,如果php編碼是gb2312那mysql編碼就是gb2312,如果是utf-8那mysql編碼就是 utf8,這樣插入或檢索數(shù)據(jù)時就不會出現(xiàn)亂碼了
看完了這篇文章,相信你對如何解決php輸出中文亂碼問題有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。