php pdo mysql 乱码,php pdo连接数据库 解决中文乱码问题(wordpress mysql 问号?? ??)...
摘要:PHP?用pdo連接數據庫時出現中文亂碼問題解決辦法1.array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"),在與數據庫建立連接的時候的第四個參數?? example:??????? $dbh = new PDO($
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
2.將文件的編碼存為UTF-8.記事本或Editplus等編輯器都有保存時選擇編碼的功能。
B.HTML和PHP混合的頁面解決方案。
除了A方案說的那些之外。還要在文件的最上面加上下面這句代碼。
view plaincopy to clipboardprint?
header("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?
header("Content-type:text/html;charset=utf-8");
?>
然后保存為UTF-8編碼的文件即可。注意和方案B一樣。注意用那些去除BOM的編輯器保存。否則還是會報錯。
D.PHP+MySQL中文亂碼解決方案
除了按方案C那樣的做法外,還要在你的數據查詢/修改/增加之前加入數據庫編碼。
view plaincopy to clipboardprint?
mysql_query('SET NAMES UTF8');
//接下來的就是查出數據或者修改,增加咯
?>
注意這里的UTF8和之前的不一樣。中間沒有橫線。
通過以上應該就能解決PHP中文亂碼的問題了。
總結
以上是生活随笔為你收集整理的php pdo mysql 乱码,php pdo连接数据库 解决中文乱码问题(wordpress mysql 问号?? ??)...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: tstringlist怎么查看是否存在该
- 下一篇: mysql query cache 关闭