很早之前就遇到过需要前端支持用户输入并提交emoji表情的问题,一直没有尝试去解决,今天再一次狭路相逢,该来的躲不过,那就着手解决吧. 大多数emoji表情都是4字节的utf-16编码(辅助平面字符,另有少部分表情属于基本平面字符2字节),而我们用的MySQL数据库采用utf-8,并且最大允许3字节的字符,因此提交用户输入的emoji表情在存入数据库的时候会报错.在后台不动的情况下,有一种解决方案就是前端将emoji表情转换为字符实体再提交. 这是一张Unicode字符百科的截图,前三个是2字节…