日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

php pdo mysql 乱码,php pdo连接数据库 解决中文乱码问题(wordpress mysql 问号?? ??)...

發(fā)布時間:2025/3/15 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php pdo mysql 乱码,php pdo连接数据库 解决中文乱码问题(wordpress mysql 问号?? ??)... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

摘要:PHP?用pdo連接數(shù)據(jù)庫時出現(xiàn)中文亂碼問題解決辦法1.array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"),在與數(shù)據(jù)庫建立連接的時候的第四個參數(shù)?? example:??????? $dbh = new PDO($

PHP?用pdo連接數(shù)據(jù)庫時出現(xiàn)中文亂碼問題解決辦法

1.array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"),在與數(shù)據(jù)庫建立連接的時候的第四個參數(shù)

example:

$dbh = new PDO($dsn,$user,$pass,array(PDO::MYSQL_ATTR_INIT_COMMAND => "set names utf8"));

下面兩種按理說應(yīng)該也能,而且有網(wǎng)友驗證了這一事實,但我沒成功!

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的頁面(這里是指真正的靜態(tài)頁面,修改服務(wù)器的……偽靜態(tài)的請看方案B)

1.在head標(biāo)簽里面加入這句

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 ”前面回車/空格)。否則會報錯。

如果你用系統(tǒng)自帶的Notepad保存為UTF-8編碼的文件時會報錯。

為什么呢?明明header已經(jīng)寫在最前面了。

不要著急,因為你看到的并不是真實的。實際上你的“<?php ”標(biāo)簽前面已經(jīng)存在了3個可惡的‘東東’,但普通編輯器看不到。如果你用UltraEdit打開并切換到16進(jìn)制模式可以看到前面多了“EF BB BF”。這是跟Windows識別編碼的方式有關(guān)。但我們的Apache卻不認(rèn)識這個,把它當(dāng)成了輸出。導(dǎo)致header出錯。別怕,還是有解決的方法。

很簡單,直接使用Editplus保存為UTF-8即可。因為Editplus的UTF-8是去除了BOM的。

C.純PHP頁面的中文亂碼解決方案(數(shù)據(jù)是靜態(tài)的)

只要在頁面的開始加上

view plaincopy to clipboardprint?

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

?>

然后保存為UTF-8編碼的文件即可。注意和方案B一樣。注意用那些去除BOM的編輯器保存。否則還是會報錯。

D.PHP+MySQL中文亂碼解決方案

除了按方案C那樣的做法外,還要在你的數(shù)據(jù)查詢/修改/增加之前加入數(shù)據(jù)庫編碼。

view plaincopy to clipboardprint?

mysql_query('SET NAMES UTF8');

//接下來的就是查出數(shù)據(jù)或者修改,增加咯

?>

注意這里的UTF8和之前的不一樣。中間沒有橫線。

通過以上應(yīng)該就能解決PHP中文亂碼的問題了。

總結(jié)

以上是生活随笔為你收集整理的php pdo mysql 乱码,php pdo连接数据库 解决中文乱码问题(wordpress mysql 问号?? ??)...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。