PHP utf-8編碼問題,utf8編碼,資料庫亂碼,頁面顯示輸出亂碼

來源:互聯網
上載者:User

老聲長談,著是困惑很多人的問題,如果處理不好,都是亂碼,說這些話並不是我對編碼很精通,只是在這方面是得留神,自己總結了一點小經驗(容易出現亂碼的地方有php檔案裡面 ,資料庫裡面 儲存 的編碼 ,頁面顯示 ,資料轉送 ):

1.在建資料庫的時候,尤其是用phpMyAdmin與MYSQL打交道時候,一般都是utf-8,欄位為 utf8_general_ci

資料庫的設定:

在my.ini檔案中尋找:
[mysql]
default-character-set = utf8
[mysqld]
default-character-set = utf8
init_connect = 'SET NAMES utf8 '
全部設定為utf8
儲存,重新啟動mysql服務

2.在與資料打交道的時候mysql_query("set names 'utf8'");注意是:utf8,不是 utf-8

3.PHP的檔案預設的編碼是ANSI ,需要轉換為UTF-8 ,至於怎麼轉換editplus就有這樣的功能,“另存新檔”的時候有選擇編碼UTF-8 ,注意:不能選擇:UTF-8 + BOM,如果選擇這個了 ,你在處理session的時候就會出現問題,所以一定要注意.還有有的人在eclipse,Myeclipse,ZendStudio裡面開發,eclipse裡面預設的是ISO-8859-1,需要在“視窗 ”->“喜好設定 ”開啟“喜好設定”視窗,在左側“常規 ”->“工作空間 ”,在“文字檔編碼 ”裡面設定預設的編碼為utf-8

4.就是PHP檔案裡面要說明:如<meta http-equiv="Content-Type" Content="text/html;charset=utf-8">

或者

複製代碼 代碼如下:<?php header('Content-Type:text/html;charset=utf-8');?>

5.還有就是處理中文等雙位元組的時候也有可能出現亂碼,PHP裡面可以採用的有iconv,mb_convert_encoding來處理雙位元組,其餘的可以參考PHP協助手冊

6.在補充一點(遺漏的一點),在你的程式裡面你要知道資料之間的傳遞也有可能存在編碼問題的,但是你又不知道傳遞過來的資料是採用的什麼編碼,在PHP裡面提供了方法來處理的,下面是自己寫的一個簡單方法,可以參考一下

複製代碼 代碼如下://編碼轉換
function display_fileencoding($filename)
{
if(extension_loaded("mbstring"))
{
$code=mb_detect_encoding($filename);//檢測字串編碼
$filename=mb_convert_encoding($filename,"UTF-8",$code);//將編碼$code轉換為utf-8編碼
return $filename;
}
else
die("請檢查系統是否正確安裝配置mbstring");
}

要確保mbstring在你的php.ini中啟用

7.保證以上幾處編碼一致就可以了!!資料庫,網頁輸出都不會出現亂碼了,如有不對的,請留言指出!!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.