emoji表情,直接存入数据库报错,,出现java.sql.SQLException: Incorrect string value: '\xF0\x9F\x98\x8E\xF0\。。。。。。

1.问题产生情况

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

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

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

3.解决

通过第三方jar包来转换emoji表情,加入maven依赖:

<dependency>
  <groupId>com.github.binarywang</groupId>
  <artifactId>java-emoji-converter</artifactId>
  <version>0.0.1</version>
</dependency>

创建一个emoji转换的工具类

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;
  }
   
   
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也是我java之路上的小小绊脚石

 有问题可加微信联系我一起学习探讨 : 18237185359

posted on 2020-03-25 14:38  不听话的M老大  阅读(517)  评论(0编辑  收藏  举报

导航