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