文章來源 http://www.lupaworld.com/forum.php?mod=viewthread&tid=148807php
A.首先說下HTML中文亂碼問題的解決方法。
好比有個index.html的頁面(這裏是指真正的靜態頁面,修改服務器的……僞靜態的請看方案B)
1.在head標籤裏面加入這句
view plaincopy to clipboardprint?
html
<head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /></head>
2.將文件的編碼存爲UTF-8.記事本或Editplus等編輯器都有保存時選擇編碼的功能。
B.HTML和PHP混合的頁面解決方案。
除了A方案說的那些以外。還要在文件的最上面加上下面這句代碼。
view plaincopy to clipboardprint?
mysql
<?phpheader("Content-type:text/html;charset=utf-8");?>
注意header前面不要有任何的輸出(echo/print/print_r/var_dump等PHP的輸出語句,或者是你在「<?php」前面回車/空格)。不然會報錯。
若是你用系統自帶的Notepad保存爲UTF-8編碼的文件時會報錯。
爲何呢?明明header已經寫在最前面了。
不要着急,由於你看到的並非真實的。實際上你的「<?php」標籤前面已經存在了3個可惡的‘東東’,但普通編輯器看不到。若是你用 UltraEdit打開並切換到16進制模式能夠看到前面多了「EF BB BF」。這是跟Windows識別編碼的方式有關。但咱們的Apache卻不認識這個,把它當成了輸出。致使header出錯。別怕,仍是有解決的方法。
很簡單,直接使用Editplus保存爲UTF-8便可。由於Editplus的UTF-8是去除了BOM的。
C.純PHP頁面的中文亂碼解決方案(數據是靜態的)
只要在頁面的開始加上
view plaincopy to clipboardprint?
sql
<?phpheader("Content-type:text/html;charset=utf-8");?>
而後保存爲UTF-8編碼的文件便可。注意和方案B同樣。注意用那些去除BOM的編輯器保存。不然仍是會報錯。
D.PHP+Mysql中文亂碼解決方案
除了按方案C那樣的作法外,還要在你的數據查詢/修改/增長以前加入數據庫編碼。
view plaincopy to clipboardprint?
數據庫
<?phpmysql_query('SET NAMES UTF8');//接下來的就是查出數據或者修改,增長咯?>
注意這裏的UTF8和以前的不同。中間沒有橫線。服務器