首頁  >  文章  >  後端開發  >  php網頁中文字元亂碼

php網頁中文字元亂碼

王林
王林原創
2019-09-19 11:54:247606瀏覽

php網頁中文字元亂碼

設定phpstudy,造訪頁面的時候出現了中文亂碼的狀況,以下是解決方案。

一、PHP網頁的編碼 

1、php檔案本身的編碼與網頁的編碼應符合

a . 如果要使用gb2312編碼,那麼php要輸出頭:header(“Content-Type: text/html; charset=gb2312"),靜態頁面新增<meta http-equiv=" Content-Type" content="text/html; charset=gb2312">,所有文件的編碼格式為​​ANSI,可用記事本打開,另存為選擇編碼為ANSI,覆蓋來源文件。

 b. 如果您想要使用utf-8編碼,那麼php要輸出頭:header(“Content-Type: text/html; charset=utf-8"),靜態頁面添加<meta http-equiv="Content-Type" content="text/html; charset=utf-8">,所有檔案的編碼格式為​​utf-8。

儲存為utf-8可能會有點麻煩,一般utf-8檔開頭會有BOM,如果使用session就會出問題,可用editplus來保存,在editplus中,工具->參數選擇- >檔->UTF-8簽名,選擇總是刪除,再儲存就可以去掉BOM資訊了。

 2、php本身不是Unicode

所有substr之類的函數得改成mb_substr(需要裝mbstring擴充),或是用iconv轉碼。

二、PHP與Mysql的資料交互

#1、PHP與資料庫的編碼應一致

修改mysql配置檔案my.ini或my.cnf,mysql最好用utf8編碼。

php網頁中文字元亂碼

2、在需要做資料庫操作的php程式前面加上mysql_query("set names '編碼'")

編碼和php編碼一致,如果php編碼是gb2312那mysql編碼就是gb2312,如果是utf-8那mysql編碼就是utf8,這樣插入或檢索資料時就不會出現亂碼了。

三、PHP與作業系統相關

Windows和Linux的編碼是不一樣的,在Windows環境下,呼叫PHP的函數時參數如果是utf- 8編碼會出現錯誤,例如move_uploaded_file()filesize()readfile()等,這些函數在處理上傳、下載時常會用到,呼叫時可能會出現錯誤。

在Linux環境下用gb2312編碼雖然不會出現這些錯誤,但保存後的文件名出現亂碼導致無法讀取文件,這時可先將參數轉換成操作系統識別的編碼,編碼轉換可用mb_convert_encoding(字串,新編碼,原始編碼)或iconv(原始編碼,新編碼,字串),這樣處理後儲存的檔案名稱就不會出現亂碼,也可以正常讀取文件,實現中文名稱文件的上傳、下載。 

其實還有更好的解決方法,徹底與系統脫離,也就不用考慮系統是何編碼。可以產生一個只有字母和數字的序列作為文件名,而將原來帶有中文的名字保存在資料庫中,這樣調用move_uploaded_file()就不會出現問題,下載的時候只需將文件名改為原來帶有中文的名字。實作下載的程式碼如下 :

php網頁中文字元亂碼

最終,其實修改一個php頁面,加上一個輸出頭即可。

php網頁中文字元亂碼

推薦教學:PHP影片教學

#

以上是php網頁中文字元亂碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn