mysql数据库:微信用户昵称emoji 怎么保存到数据库中。

本文介绍了一种在MySQL中处理emoji字符导致的存储错误的方法,包括调整字段编码为utf8mb4以及提供一种过滤emoji字符的实用工具。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  我单位的小姐姐  也满逗的   每次测试微信公众号  总会报错。如下图:


java.sql.SQLException: Incorrect string value: ‘\xF0\x9F\x91\xA7’ for colum n ‘nickname’ at row 1 
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525) 
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986) 
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140) 
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)

  

这个就很尴尬  所有人都可以正常登陆 唯独她不可以   慢慢排查发现是因为昵称中带有emoji 图片  额   好吧  来解决    

经过百度  试了各种办法   只有这个挺可靠

mysql表字段定义为utf8mb4

MySQL在5.5.3版本之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。其实,utf8mb4是utf8的超集,理论上原来使用utf8,然后将字符集修改为utf8mb4,也会不会对已有的utf8编码读取产生任何问题。当然,为了节省空间,一般情况下使用utf8也就够了。

`third_name` varchar(255) CHARACTER SET utf8mb4 DEFAULT NULL COMMENT '用户第三方账号昵称',

注意改成了“utf8mb4”,不再是utf8,主要是支持的字节数不同。

    但是我试过发现也不OK    所以索性就写了一个工具类   用来过滤名字



    package com.utils;


    import org.apache.commons.lang.StringUtils;


















    /**过滤emoji工具*/
    public class NickNameFilter {
    /**检测是否有emoji字符
    * 有的话抛出
    * */  
        public static boolean containsEmoji(String source) {  
            if (StringUtils.isBlank(source)) {  
                return false;  
            }  
            int len = source.length();  
            for (int i = 0; i < len; i++) {  
                char codePoint = source.charAt(i);  
                if (isEmojiCharacter(codePoint)) {  
                    //do nothing,判断到了这里表明,确认有表情字符  
                    return true;  
                }  
            }  
            return false;  
        }  
      
        private static boolean isEmojiCharacter(char codePoint) {  
            return (codePoint == 0x0) ||  
                    (codePoint == 0x9) ||  
                    (codePoint == 0xA) ||  
                    (codePoint == 0xD) ||  
                    ((codePoint >= 0x20) && (codePoint <= 0xD7FF)) ||  
                    ((codePoint >= 0xE000) && (codePoint <= 0xFFFD)) ||  
                    ((codePoint >= 0x10000) && (codePoint <= 0x10FFFF));  
        }  
      
        /** 
         * 过滤emoji 或者 其他非文字类型的字符 
         * 
         * @param source 
         * @return 
         */  
        public static String filterEmoji(String source) {  
            source = source.replaceAll("[\\ud800\\udc00-\\udbff\\udfff\\ud800-\\udfff]", "*");  
            if (!containsEmoji(source)) {  
                return source;//如果不包含,直接返回  
            }  
            //到这里铁定包含  
            StringBuilder buf = null;  
      
            int len = source.length();  
      
            for (int i = 0; i < len; i++) {  
                char codePoint = source.charAt(i);  
      
                if (isEmojiCharacter(codePoint)) {  
                    if (buf == null) {  
                        buf = new StringBuilder(source.length());  
                    }  
      
                    buf.append(codePoint);  
                } else {  
                    buf.append("*");  
                }  
            }  
      
            if (buf == null) {  
                return source;//如果没有找到 emoji表情,则返回源字符串  
            } else {  
                if (buf.length() == len) {//这里的意义在于尽可能少的toString,因为会重新生成字符串  
                    buf = null;  
                    return source;  
                } else {  
                    return buf.toString();  
                }  
            }  
      
        }  
    }






    就可以了




    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值