一什么是Emoji
emoji就是表情符号;词义来自日语(えもじ,e-moji,moji在日语中的含义是字符)
表情符号现已普遍应用于手机短信和网络聊天软件。
emoji表情符号,在外国的手机短信里面已经是很流行使用的一种表情。
手机上如何使用emoji:
1.iphone、ipad系统:安装emojifree,再设置-通用-键盘-国际键盘-添加新的键盘,然后把emoji添加在里面即可在发短信和一些输入文本的文本框中输入表情。
IOS5用户可直接从通用中添加emoji键盘,无需再安装emojifree
2.android系统:安装“GO输入法国际版”后,在输入法里面点选安装emoji插件可以使用。另外“百度输入法”也自带emoji表情
3.WindowsPhone:安装此EmojiKeys,在其中输入之后复制粘贴到需要输入表情的地方即可
<此段摘自百度百科/view/2631589.htm>
二Emoji表情符号问题
1问题:
IOS版本之间发送的Emoji表情符号不兼容,只看到方块
不同IOS版本在数据库存数据时,有时会发生系统错误
2现象:
IOS4输入Emoji表情符,在IOS5.01显示正常,在IOS5.1中(大陆版)显现为方块,但IOS5.01/5.1输入的表情符号,显示正常
IOS5.01/5.1输入表情符,在IOS5.01/5.1中显示正常,但在IOS4.X显示为方块
输入Emoji入帖子正文,可正常存储。但用户昵称在IOS4.X输入Emoji,系统正常,而IOS5.01/5.1则提示系统错误。
3本质:
iOS5andOSX10.7(Lion)usetheUnicode6.0standard‘unified’codepointsforemoji.
iOS5Emoji采用Unicode6标准来统一codepoints
iOS4onSoftBankiPhonesusedasetofunofficialcodepointsintheUnicodePrivateUseArea,andsoaren'tcompatiblewithanyothersystems
iOS4采用SoftBankUnicode,一种非官方的,采用私有Unicode区域。
4举例:
oneemojisymbol"tiger",itis"\U0001f42f"iniOS5,but"\ue050"inearlieriOSversion
虎脸Emoji符号在iOS5为Unicode:\U0001f42f;而在IOS4.x为:\ue050(SoftBank编码)
另外:按理讲,从iOS5应该兼容以前版本的emoji,但现在出现5.01版本完美兼容(无论大陆版,美版,还是港版),而5.1大陆版出现了不兼容现象(腾讯微信也出现了同样的问题)。
三问题分析
1系统存储错误问题(如昵称,帖子内容)
原因:
由于IOS5.X采用新的Unicode,其UTF8编码大多为4个字节,而由于昵称/帖子内容column并没设成utf8mb4,因此存储会发生错误。
解决方法:
将昵称/帖子内容设成utf8mb4
2不同iOS之间Emoji不兼容的问题。
原因:
iOS5到4不兼容的问题,很简单,unicode6和softbank编码的不同
iOS4到5,按理说应该兼容,也就是说,iOS应该自动判断如果是softbank编码,自动转成unicode6。但现在看来,iOS5.1(大陆版)好像只支持unicode6,而不支持softbank.
解决方法:
客户端发送emoji-encoding:Softbank或unicode6,由服务端分别给出相应的编码表。
四解决方案
1数据存储(MySQLvarchar数据类型对UTF8支持问题)
MYSQL5.5之前,UTF8编码只支持1-3个字节,从MYSQL5.5开始,可支持4个字节UTF编码,但要特殊标记。例如我们的帖子内容项,我们加上了这个支持。服务端mysql统一存储为ios5.x也就是Unicode编码。
对应alter语句:
ALTERTABLEtopicMODIFYCOLUMNcontentvarchar(500)CHARACTERSETutf8mb4COLLATEutf8mb4_unicode_ciDEFAULTNULLCOMMENT'内容';
2编码转换:
iphone手机方案
客户端输入内容时候,统一存储为unicode编码(这里需要从softbank编码转换为unicode编码)。客户端请求内容的时候,需要根据不同的客户端给出不同的编码,ios4采用softbank编码做替换,ios5采用unicode编码直接支持。
android或wp其他手机方案:
如果没有emoji表情库,将无法输入。针对输入问题,将统一采用unicode编码存储。客户端请求内容的时候,将统一用softbank编码,客户端需要把emoji表情符号内置到客户端,做对应的编码和img替换。
web解决方案:
参考android或wp其他手机方案
五部分代码
1sql代码
SQL code ?
2java代码
Java code ?
六参考资料
1Emoji全编码表:(我参考的这个)
/iOSEmoji/table_html/flower.html
2Emoji全编码表
/php/emoji/
3iOS5/4Emoji兼容性:
/questions/7856775/how-to-convert-the-old-emoji-encoding-to-the-latest-encoding-in-ios5
4MySQLemoji问题
/archives/ios-mysql-emoji
5Emoji中文对应表
http://www.iapps.im/wp-content/uploads//02/emoji-pinyin.png?r=010
七下载资源
emoji图片和编码表/detail/qdkfriend/4309051
包括emoji文件表,emoji数据编码表(Unicode编码,UTF8编码,UTF16编码,SBUnicode编码)
原文: /qdkfriend/article/details/7576524