zoukankan      html  css  js  c++  java
  • emoji表情,直接存入数据库报错,,出现java.sql.SQLException: Incorrect string value: 'xF0x9Fx98x8ExF0。。。。。。

    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

  • 相关阅读:
    使用OCR来帮助LR实现认证码识别
    Oracle的AWR报告分析
    oracle创建表空间
    Bug管理工具之Mantis_配置篇
    Selenium学习笔记之外部化相关测试数据---xml
    性能测试学习之二 ——性能测试模型(PV计算模型)
    性能测试学习之三—— PV->TPS转换模型&TPS波动模型
    性能测试学习之一 ——性能测试指标
    性能测试之吞吐量
    记录几个 Android x86 系统的官网
  • 原文地址:https://www.cnblogs.com/livedian/p/12566141.html
Copyright © 2011-2022 走看看