php讀取資料庫中文亂碼解決方法:1.使用「mysql_query」函數來設定MYSQL連線編碼,確保頁面申明編碼與這裡設定的連線編碼一致;2、用FTP軟體直接線上修改檔案;3、在設定檔自己的虛機裡加上一條「AddDefaultCharset GB2312」來覆寫全域配置,或是在目錄的.htaccess裡配置。
本教學操作環境:windows10系統、PHP8.1.3版,dell g3電腦。
php讀取資料庫的中文亂碼原因:
一般來說,亂碼的出現有2種原因,首先是由於編碼(charset)設定錯誤,導致瀏覽器以錯誤的編碼來解析,從而出現了滿屏亂七八糟的“天書”,其次是文件被以錯誤的編碼打開,然後保存,比如一個文本文件原先是GB2312編碼的,卻以UTF-8編碼打開再保存。要解決上述亂碼問題,首先需要知道開發中哪些環節涉及到了編碼:
1、文件編碼:指的是頁面文件(.html,.php等)本身是以何種編碼來保存的。記事本和Dreamweaver在開啟頁面時會自動辨識文件編碼因而不太會出問題。而ZendStudio卻不會自動識別編碼,它只會根據首選項的配置固定以某種編碼打開文件,如果工作時候一不注意,用錯誤編碼打開文件,做了修改之後一保存,亂碼就出現了。
2、頁面申明編碼:在HTML代碼HEAD裡面,可以用《meta http-equiv=“Content-Type” content=“text/html; charset=”XXX“ /”(這句一定要寫在《TItle》XXX《/TItle》前面,否則會導致頁面一片空白(僅限IE PHP))來告訴瀏覽器網頁採用了什麼編碼,目前中文網站開發中主要用的是GB2312和UTF-8兩種編碼。
3、資料庫連接編碼:指的是進行資料庫操作時候以哪種編碼與資料庫傳輸數據,這裡需要注意的是不要與資料庫本身的編碼混淆,例如MySQL內部預設是laTIn1編碼,也就是說Mysql是以laTIn1編碼來儲存數據,以其他編碼傳輸給Mysql的數據會被轉換成latin1編碼。
知道了WEB開發中哪些地方涉及到了編碼,也就知道了亂碼產生的原因:上述3項編碼設定不一致,由於各種編碼絕大部分是相容ASCII的,所以英文符號不會出現,中文就倒楣了。
##下面是一些常見的錯誤狀況與解決:
1、資料庫採用UTF8編碼,而頁面申明編碼是GB2312,這是最常見的產生亂碼的原因。這時候在PHP腳本裡面直接SELECT資料出來的就是亂碼,需要在查詢前先使用:mysql_query(”SET NAMES GBK“); 或mysql_query(”SET NAMES GB2312“);
mysql_query(”SET NAMES UTF8“);
以上是php讀取資料庫的中文亂碼怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!