設定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編碼。
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中文網其他相關文章!