【轉】php pdo串連資料庫 解決中文亂碼問題(wordpress mysql 問號?? ??)

來源:互聯網
上載者:User

標籤:代碼   通過   ase   這一   使用   base   進位   pass   windows   

原文連結:http://blog.csdn.net/ysydao/article/details/11002295

PHP 用pdo串連資料庫時出現中文亂碼問題解決辦法

1.array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"),在與資料庫建立串連的時候的第四個參數
   example:    
    $dbh = new PDO($dsn,$user,$pass,array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"));
下面兩種按理說應該也能,而且有網友驗證了這一事實,但我沒成功!
2.通過query():
     $dbh = new PDO($dsn,$user,$pass);
     $dbh -> query(‘set names utf-8‘);
3.通過esec(): 
     $dbh = new PDO($dsn,$user,$pass);
     $dbh -> exec(‘set names utf-8‘);

 

A.首先說下HTML中文亂碼問題的解決方案。
比如有個index.html的頁面(這裡是指真正的靜態頁面,修改伺服器的……偽靜態請看方案B)
1.在head標籤裡面加入這句
view plaincopy to clipboardprint

<head>   
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />  

</head>  

<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?
<?php  

header("Content-type:text/html;charset=utf-8");   
?>  
<?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?
<?php  

header("Content-type:text/html;charset=utf-8");  

?>  


<?phpheader("Content-type:text/html;charset=utf-8");?> 
然後儲存為UTF-8編碼的檔案即可。注意和方案B一樣。注意用那些去除BOM的編輯器儲存。否則還是會報錯。

D.PHP+MySQL中文亂碼解決方案
除了按方案C那樣的做法外,還要在你的資料查詢/修改/增加之前加入資料庫編碼。
view plaincopy to clipboardprint?
<?php  

 mysql_query(‘SET NAMES UTF8‘);   
//接下來的就是查出資料或者修改,增加咯   

?>  


<?phpmysql_query(‘SET NAMES UTF8‘);//接下來的就是查出資料或者修改,增加咯?> 

注意這裡的UTF8和之前的不一樣。中間沒有橫線。
通過以上應該就能解決PHP中文亂碼的問題了。

【轉】php pdo串連資料庫 解決中文亂碼問題(wordpress mysql 問號?? ??)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.