中文字幕理论片,69视频免费在线观看,亚洲成人app,国产1级毛片,刘涛最大尺度戏视频,欧美亚洲美女视频,2021韩国美女仙女屋vip视频

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
mysql utf8mb4與emoji表情



MYSQL 5.5 之前, UTF8 編碼只支持1-3個字節(jié),只支持BMP這部分的unicode編碼區(qū), BMP是從哪到哪,到http://en.wikipedia.org/wiki/Mapping_of_Unicode_characters這里看,基本就是0000~FFFF這一區(qū)。 從MYSQL5.5開始,可支持4個字節(jié)UTF編碼utf8mb4,一個字符最多能有4字節(jié),所以能支持更多的字符集。

utf8mb4 is a superset of utf8

utf8mb4兼容utf8,且比utf8能表示更多的字符。 


至于什么時候用,看你的做什么項目了。。

在做移動應用時,會遇到ios用戶會在文本的區(qū)域輸入emoji表情,如果不做一定處理,就會導致插入數據庫異常。


Emoji表情符號兼容方案

一 什么是Emoji   

      emoji就是表情符號;詞義來自日語(えもじ,e-moji,moji在日語中的含義是字符)
  表情符號現已普遍應用于手機短信和網絡聊天軟件。
  emoji表情符號,在外國的手機短信里面已經是很流行使用的一種表情。
  手機上如何使用emoji:
  1.iphone、ipad系統(tǒng):安裝emoji free,再設置-通用-鍵盤-國際鍵盤-添加新的鍵盤,然后把emoji添加在里面即可在發(fā)短信和一些輸入文本的文本框中輸入表情。
  IOS 5用戶可直接從通用中添加emoji 鍵盤,無需再安裝emoji free
  2.android系統(tǒng):安裝“GO輸入法國際版”后,在輸入法里面點選安裝emoji插件可以使用。另外“百度輸入法”也自帶emoji表情
  3.Windows Phone : 安裝此 Emoji Keys,在其中輸入之后復制粘貼到需要輸入表情的地方即可

    <此段摘自百度百科 http://baike.baidu.com/view/2631589.htm>

二 Emoji表情符號問題
   1 問題:
     IOS版本之間發(fā)送的Emoji表情符號不兼容,只看到方塊
     不同IOS版本在數據庫存數據時,有時會發(fā)生系統(tǒng)錯誤
   2 現象:
     IOS 4 輸入Emoji表情符,在IOS5.01 顯示正常,在IOS5.1中(大陸版)顯現為方塊, 但IOS5.01/5.1輸入的表情符號,顯示正      常
     IOS5.01/5.1 輸入表情符,在IOS5.01/5.1中顯示正常,但在IOS4.X顯示為方塊
     輸入Emoji入帖子正文, 可正常存儲。 但用戶昵稱在IOS4.X 輸入Emoji,系統(tǒng)正常, 而IOS5.01/5.1則提示系統(tǒng)錯誤。
   3 本質:
     iOS 5 and OS X 10.7 (Lion) use the Unicode 6.0 standard ‘unified’ code points for emoji.
     iOS 5 Emoji  采用Unicode 6 標準來統(tǒng)一code points 

     iOS 4 on SoftBank iPhones used a set of unofficial code points in the Unicode Private Use Area, and so aren't      compatible with any other systems
     iOS 4 采用SoftBank Unicode, 一種非官方的, 采用私有Unicode 區(qū)域。
   4 舉例:
     
one emoji symbol "tiger", it is "\U0001f42f" in iOS5, but "\ue050" in earlier iOS version
    虎臉Emoji符號在iOS5 為Unicode:\U0001f42f;而在IOS4.x 為:\ue050 (SoftBank 編碼)
    另外: 按理講, 從iOS5 應該兼容以前版本的emoji, 但現在出現5.01版本完美兼容(無論大陸版,美版,還是港版), 而5.1     大陸版出現了不兼容現象(騰訊微信也出現了同樣的問題)。
三 問題分析
   1 系統(tǒng)存儲錯誤問題(如昵稱,帖子內容)
    原因:
    由于IOS5.X 采用新的Unicode, 其UTF8 編碼大多為4個字節(jié), 而由于昵稱/帖子內容column并沒設成utf8mb4,因此存儲會    發(fā)生錯誤。
    解決方法:
    將昵稱/帖子內容設成utf8mb4
   2 不同iOS 之間Emoji 不兼容的問題。 
   原因:
   iOS 5 到4 不兼容的問題,很簡單,unicode6 和softbank編碼的不同
   iOS 4 到 5,按理說應該兼容,也就是說,iOS應該自動判斷如果是softbank編碼,自動轉成unicode6。但現在看來, iOS5.1(大陸版)好像只支持unicode6, 而不支持softbank. 
   解決方法: 
   客戶端發(fā)送emoji-encoding: Softbank或unicode6, 由服務端分別給出相應的編碼表。
四 解決方案
   1 數據存儲(MySQL varchar  數據類型對UTF8 支持問題)
    MYSQL 5.5 之前, UTF8 編碼只支持1-3個字節(jié), 從MYSQL5.5開始,可支持4個字節(jié)UTF編碼,但要特殊標記。例如我們的帖子內容項,我們加上了這個支持。服務端mysql統(tǒng)一存儲為ios5.x也就是Unicode編碼。
   對應alter語句:
[sql]  view plain copy
  1. ALTER TABLE topic MODIFY COLUMN content varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '內容';  
    2 編碼轉換:
    iphone手機方案
    客戶端輸入內容時候,統(tǒng)一存儲為unicode編碼(這里需要從softbank編碼轉換為unicode編碼)??蛻舳苏埱髢热莸臅r候,需要根據不同的客戶端給出不同的編碼,ios4采用softbank編碼做替換,ios5采用unicode編碼直接支持。
    android或wp其他手機方案:
    如果沒有emoji表情庫,將無法輸入。針對輸入問題,將統(tǒng)一采用unicode編碼存儲??蛻舳苏埱髢热莸臅r候,將統(tǒng)一用softbank編碼,客戶端需要把emoji表情符號內置到客戶端,做對應的編碼和img替換。
    web解決方案:
    參考android或wp其他手機方案
五 部分代碼
   1 sql代碼
[sql]  view plain copy
  1. CREATE TABLE `ios_emoji` (  
  2.   `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增ID',  
  3.   `unicode` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'Unicode編碼',  
  4.   `utf8` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'UTF8編碼',  
  5.   `utf16` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'UTF16編碼',  
  6.   `sbunicode` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT 'SBUnicode編碼',  
  7.   `filename` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT '文件名',  
  8.   `filebyte` longblob COMMENT '文件內容字節(jié)',  
  9.   PRIMARY KEY (`id`)  
  10. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT COMMENT='ios表情編碼表';  

   2 java代碼
[java]  view plain copy
  1. import java.io.UnsupportedEncodingException;  
  2. import org.apache.commons.lang.StringUtils;  
  3.   
  4.   
  5. public class IOSEmojiUtil {  
  6.       
  7.     public static String[] ios5emoji ;  
  8.     public static String[] ios4emoji ;  
  9.     public static String[] androidnullemoji ;  
  10.     public static String[] adsbuniemoji;  
  11.       
  12.     public static void initios5emoji(String[] i5emj,String[] i4emj,String[] adnullemoji,String[] adsbemoji){  
  13.         ios5emoji = i5emj;  
  14.         ios4emoji = i4emj;  
  15.         androidnullemoji = adnullemoji;  
  16.         adsbuniemoji = adsbemoji;  
  17.     }  
  18.       
  19.     //在ios上將ios5轉換為ios4編碼  
  20.     public static String transToIOS4emoji(String src) {  
  21.         return StringUtils.replaceEach(src, ios5emoji, ios4emoji);  
  22.     }  
  23.     //在ios上將ios4轉換為ios5編碼  
  24.     public static String transToIOS5emoji(String src) {  
  25.         return StringUtils.replaceEach(src, ios4emoji, ios5emoji);  
  26.     }  
  27.     //在android上將ios5的表情符替換為空  
  28.     public static String transToAndroidemojiNull(String src) {  
  29.         return StringUtils.replaceEach(src, ios5emoji, androidnullemoji);  
  30.     }  
  31.       
  32.     //在android上將ios5的表情符替換為SBUNICODE  
  33.     public static String transToAndroidemojiSB(String src) {  
  34.         return StringUtils.replaceEach(src, ios5emoji, adsbuniemoji);  
  35.     }  
  36.       
  37.     //在android上將SBUNICODE的表情符替換為ios5  
  38.     public static String transSBToIOS5emoji(String src) {  
  39.         return StringUtils.replaceEach(src, adsbuniemoji, ios5emoji);  
  40.     }  
  41.       
  42.     //eg. param: 0xF0 0x9F 0x8F 0x80  
  43.     public static String hexstr2String(String hexstr) throws UnsupportedEncodingException{  
  44.         byte[] b = hexstr2bytes(hexstr);  
  45.         return new String(b, "UTF-8");  
  46.     }  
  47.       
  48.     //eg. param: E018  
  49.     public static String sbunicode2utfString(String sbhexstr) throws UnsupportedEncodingException{  
  50.         byte[] b = sbunicode2utfbytes(sbhexstr);  
  51.         return new String(b, "UTF-8");  
  52.     }  
  53.       
  54.     //eg. param: 0xF0 0x9F 0x8F 0x80  
  55.     public static byte[] hexstr2bytes(String hexstr){  
  56.         String[] hexstrs = hexstr.split(" ");  
  57.         byte[] b = new byte[hexstrs.length];  
  58.           
  59.         for(int i=0;i<hexstrs.length;i++){  
  60.             b[i] = hexStringToByte(hexstrs[i].substring(2))[0];  
  61.         }  
  62.         return b;  
  63.     }  
  64.       
  65.     //eg. param: E018  
  66.     public static byte[] sbunicode2utfbytes(String sbhexstr) throws UnsupportedEncodingException{  
  67.         int inthex = Integer.parseInt(sbhexstr, 16);  
  68.         char[] schar = {(char)inthex};  
  69.         byte[] b = (new String(schar)).getBytes("UTF-8");  
  70.         return b;  
  71.     }  
  72.       
  73.     public static byte[] hexStringToByte(String hex) {  
  74.         int len = (hex.length() / 2);  
  75.         byte[] result = new byte[len];  
  76.         char[] achar = hex.toCharArray();  
  77.         for (int i = 0; i < len; i++) {  
  78.             int pos = i * 2;  
  79.             result[i] = (byte) (toByte(achar[pos]) << 4 | toByte(achar[pos + 1]));  
  80.         }  
  81.         return result;  
  82.     }  
  83.   
  84.   
  85.     private static byte toByte(char c) {  
  86.         byte b = (byte"0123456789ABCDEF".indexOf(c);  
  87.         return b;  
  88.     }  
  89.       
  90.     public static void main(String[] args) throws UnsupportedEncodingException {  
  91.         // TODO Auto-generated method stub  
  92.         byte[] b1 = {-30,-102,-67}; //ios5 //0xE2 0x9A 0xBD       
  93.         byte[] b2 = {-18,-128,-104}; //ios4 //"E018"  
  94.           
  95.         //-------------------------------------  
  96.           
  97.         byte[] b3 = {-16,-97,-113,-128};    //0xF0 0x9F 0x8F 0x80         
  98.         byte[] b4 = {-18,-112,-86};         //E42A    
  99.           
  100.           
  101.         ios5emoji = new String[]{new String(b1,"utf-8"),new String(b3,"utf-8")};  
  102.         ios4emoji = new String[]{new String(b2,"utf-8"),new String(b4,"utf-8")};      
  103.           
  104.           
  105.         //測試字符串  
  106.         byte[] testbytes = {105,111,115,-30,-102,-67,32,36,-18,-128,-104,32,36,-16,-97,-113,-128,32,36,-18,-112,-86};  
  107.         String tmpstr = new String(testbytes,"utf-8");  
  108.         System.out.println(tmpstr);  
  109.           
  110.           
  111.         //轉成ios4的表情  
  112.         String ios4str = transToIOS5emoji(tmpstr);  
  113.         byte[] tmp = ios4str.getBytes();  
  114.         //System.out.print(new String(tmp,"utf-8"));          
  115.         for(byte b:tmp){  
  116.             System.out.print(b);  
  117.             System.out.print(" ");  
  118.         }  
  119.     }  
  120.       
  121. }  


六 參考資料
1 Emoji 全編碼表:(我參考的這個)
  http://punchdrunker.github.com/iOSEmoji/table_html/flower.html
2 Emoji全編碼表
  http://code.iamcal.com/php/emoji/

3 iOS5/4 Emoji  兼容性:
  http://stackoverflow.com/questions/7856775/how-to-convert-the-old-emoji-encoding-to-the-latest-encoding-in-ios5
4 MySQL emoji問題
  http://dropblood.com/archives/ios-mysql-emoji
5 Emoji 中文對應表
  http://www.iapps.im/wp-content/uploads/2012/02/emoji-pinyin.png?r=010

七 下載資源 

emoji圖片和編碼表 http://download.csdn.net/detail/qdkfriend/4309051

  包括emoji文件表,emoji數據編碼表(Unicode編碼,UTF8編碼,UTF16編碼,SBUnicode編碼) 



mysql支持utf8mb4升級方案



本站僅提供存儲服務,所有內容均由用戶發(fā)布,如發(fā)現有害或侵權內容,請點擊舉報
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
iOS 10 或新增72個 Emoji:簡直不能更魔性
iOS 10 將新增72個Emoji 表情,魔性十足
springboot+mysql程序插入微信表情(emoji)錯誤
每天都用的黃色球球表情,竟然都是日本人
mysql字符集問題
求求你,別在MySQL中使用UTF-8了!
更多類似文章 >>
生活服務
熱點新聞
分享 收藏 導長圖 關注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服