Web 開發(fā)中遇到的UTF-8編碼的問題總結(jié)
三.MYSQL數(shù)據(jù)庫使用UTF-8編碼的問題
1.用phpmyadmin創(chuàng)建數(shù)據(jù)庫和數(shù)據(jù)表
創(chuàng)建數(shù)據(jù)庫的時候,請將“整理”設(shè)置為:“utf8_general_ci”或執(zhí)行語句:
CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; |
創(chuàng)建數(shù)據(jù)表的時候:如果是該字段是存放中文的話,則需要將“整理”設(shè)置為:“utf8_general_ci”,
如果該字段是存放英文或數(shù)字的話,默認(rèn)就可以了。
相應(yīng)的SQL語句,例如:
CREATE TABLE `test` ( `id` INT NOT NULL , `name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL , PRIMARY KEY ( `id` ) ) ENGINE = MYISAM ; |
2.用PHP讀寫數(shù)據(jù)庫
在連接數(shù)據(jù)庫之后:
$connection = mysql_connect($host_name, $host_user, $host_pass); |
加入兩行:
mysql_query("set character set 'utf8'");//讀庫 mysql_query("set names 'utf8'");//寫庫 |
就可以正常的讀寫MYSQL數(shù)據(jù)庫了。
四.JS相關(guān)的UTF-8編碼問題
1.JS讀Cookie的中文亂碼問題
PHP寫cookie的時候需要將中文字符進行escape編碼,否則JS讀到cookie中的中文字符將是亂碼。
但php本身沒有escape函數(shù),我們新寫一個escape函數(shù):
function escape($str) { preg_match_all("/[\x80-\xff].|[\x01-\x7f]+/",$str,$r); $ar = $r[0]; foreach($ar as $k=>$v) { if(ord($v[0]) < 128) $ar[$k] = rawurlencode($v); else $ar[$k] = "%u".bin2hex(iconv("UTF-8","UCS-2",$v)); } return join("",$ar); } |
JS讀cookie的時候,用unescape解碼,然后就解決cookie中有中文亂碼的問題了。
2.外部JS文件UTF-8編碼問題
當(dāng)一個HTML頁面或則PHP頁面包含一個外部的JS文件時,如果HTML頁面或則PHP頁面是UTF-8編碼格式的文件,外部的JS文件同樣要轉(zhuǎn)成UTF-8的文件,否則將出現(xiàn),沒有包含不成功,調(diào)用函數(shù)時沒有反應(yīng)的情況。
點擊編輯器的菜單:“文件”->“另存為”,可以看到當(dāng)前文件的編碼,確保文件編碼為:UTF-8,如果是ANSI,需要將編碼改成:UTF-8。
五.FLASH相關(guān)的UTF-8編碼問題
FLASH內(nèi)部對所有字符串,默認(rèn)都是以UTF-8處理
1.FLASH讀文普通本文件(txt,html)
要將文本文件的編碼存為UTF-8
點擊編輯器的菜單:“文件”->“另存為”,可以看到當(dāng)前文件的編碼,確保文件編碼為:UTF-8,如果是ANSI,需要將編碼改成:UTF-8。
2.FLASH讀XML文件
要將XML文件的編碼存為UTF-8
點擊編輯器的菜單:“文件”->“另存為”,可以看到當(dāng)前文件的編碼,確保文件編碼為:UTF-8,如果是ANSI,需要將編碼改成:UTF-8。
在XML第1行寫:
<?xml version="1.0" encoding="utf-8"?> |
3.FLASH讀PHP返回數(shù)據(jù)
如果PHP編碼本身是UTF-8的,直接echo就可以了。
如果PHP編碼本身是GB2312的,可以將PHP轉(zhuǎn)存成UTF-8編碼格式的文件,直接echo就可以了
如果PHP編碼本身是GB2312的,而且不允許改文件的編碼格式,用下面的語句將字符串轉(zhuǎn)換成UTF-8的編碼格式
$new_str = iconv("GB2312", "UTF-8", "$str"); |
再echo就可以了
4.FLASH讀數(shù)據(jù)庫(MYSQL)的數(shù)據(jù)
FLASH要通過PHP讀取數(shù)據(jù)庫中的數(shù)據(jù),PHP本身的編碼不重要,關(guān)鍵是如果數(shù)據(jù)庫的編碼是GB2312的話,需要用下面的語句將字符串轉(zhuǎn)換成UTF-8的編碼格式。
$new_str = iconv("GB2312", "UTF-8", "$str"); |
5.FLASH通過PHP寫數(shù)據(jù)
一句話,F(xiàn)LASH傳過來的字符串是UTF-8格式的,要轉(zhuǎn)換成相應(yīng)的編碼格式,再操作(寫文件、寫數(shù)據(jù)庫、直接顯示等等),還是用iconv函數(shù)轉(zhuǎn)換。
6.FLASH使用本地編碼(理論上不推薦使用)
如果想讓FLASH不使用UTF-8編碼,而是使用本地編碼。對于中國大陸地區(qū)而言,本地編碼是GB2312或GBK
AS程序內(nèi),可以添加以下代碼:
System.useCodepage = true; |
那么FLASH內(nèi)所有字符都是使用GB2312的編碼了,所有導(dǎo)入到FLASH或者從FLASH導(dǎo)出的數(shù)據(jù),都應(yīng)該做相應(yīng)的編碼轉(zhuǎn)換。
因為使用本地編碼,會造成使用繁體中文地區(qū)的用戶產(chǎn)生亂碼,所以不推薦使用。
相關(guān)文章
IntelliJ IDEA 2020如何設(shè)置背景圖片的方法步驟
這篇文章主要介紹了IntelliJ IDEA 2020如何設(shè)置背景圖片的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04解決SecureCRT通過SSH連接Ubuntu時vi命令有多余的m的問題
小編遇到這樣一個問題用vi命令來編輯文件的時候,在開頭和結(jié)尾有多余的字母出現(xiàn):在開頭會有多余的“m”出現(xiàn),結(jié)尾有多余的“2m”,這篇文章主要介紹了解決SecureCRT通過SSH連接Ubuntu時vi命令有多余的m的問題,需要的朋友可以參考下2022-09-09基于域名的方式訪問Istio服務(wù)網(wǎng)格中的多個應(yīng)用程序的方法詳解
這篇文章主要介紹了基于域名的方式訪問Istio服務(wù)網(wǎng)格中的多個應(yīng)用程序,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07Typora?1.4.8激活?2022最新Typora破解激活使用教程
Typora?for?mac?是一款簡潔的markdown編輯器、寫作軟件。它去除了預(yù)覽窗口,模式切換器,語法符號以及所有其他不必要的干擾,今天給大家分享Typora?1.4.8?最新Typora破解激活使用教程,感興趣的朋友跟隨小編一起看看吧2023-01-01反向傳播BP學(xué)習(xí)算法Gradient?Descent的推導(dǎo)過程
這篇文章主要為大家介紹了反向傳播BP學(xué)習(xí)算法-Gradient?Descent的推導(dǎo)過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05