zoukankan      html  css  js  c++  java
  • java emoji表情存储解决方案

    1.问题产生情况

    我遇到这个问题是做微信开发的时候有些有用的头像用了微信的emoji表情,然而我的mysql数据库用的编码是utf8_general_ci,就是utf-8编码,结果也就报错误了。

    2.为什么会出现这种原因

    因为mysql的utf8编码的一个字符最多3个字节,但是一个emoji表情为4个字节,所以utf8不支持存储emoji表情。但是utf8的超集utf8mb4一个字符最多能有4字节,所以能支持emoji表情的存储。

    3.解决方法之一

    把你的数据库编码集设置为utf8mb4,无论是数据库还是表,还是字段。虽然会增加存储,但是这个可以忽略不计。

    4.解决方法之二

    有句话说得好,问题来了要么解决要么折中解决。如果有些原因你不能修改数据库编码之类的,你可以用java的一些插件,如emoji-java这种emoji表情插件对表情进行特殊处理,然后保存或者去掉表情,这也是一种解决方法哦。

    5.最后说点什么

    通过对一个问题不同角度的思考,原来才发现世界同而不同,不同而同......

    最后来段代码:

    复制代码
    import com.github.binarywang.java.emoji.EmojiConverter;
    
    
    /**
     * 表情处理类
     * @author Administrator
     *
     */
    public final class EmojiUtil {
    
        private static EmojiConverter emojiConverter = EmojiConverter.getInstance();
        
        /**
         * 将emojiStr转为 带有表情的字符
         * @param emojiStr
         * @return
         */
        public static String emojiConverterUnicodeStr(String emojiStr){
             String result = emojiConverter.toUnicode(emojiStr);
             return result;
        }
        
        /**
         * 带有表情的字符串转换为编码
         * @param str
         * @return
         */
        public static String emojiConverterToAlias(String str){
            String result=emojiConverter.toAlias(str);
            return result;
        }
        
        
    }
    复制代码

    使用的框架是:

    <dependency>
        <groupId>com.github.binarywang</groupId>
        <artifactId>java-emoji-converter</artifactId>
        <version>0.0.1</version>
    </dependency>
  • 相关阅读:
    POJ 2236 Wireless Network(并查集)
    POJ 2010 Moo University
    POJ 3614 Sunscreen(贪心,区间单点匹配)
    POJ 2184 Cow Exhibition(背包)
    POJ 1631 Bridging signals(LIS的等价表述)
    POJ 3181 Dollar Dayz(递推,两个long long)
    POJ 3046 Ant Counting(递推,和号优化)
    POJ 3280 Cheapest Palindrome(区间dp)
    POJ 3616 Milking Time(dp)
    POJ 2385 Apple Catching(01背包)
  • 原文地址:https://www.cnblogs.com/Thinkingcao/p/9331127.html
Copyright © 2011-2022 走看看