MySQL 字符串删除表情符_字符串中Emoji表情处理「终于解决」

MySQL 字符串删除表情符_字符串中Emoji表情处理「终于解决」吃了经验的亏,因为Emoji表情引起的项目bug被撸主遇到两次了,总有一些调皮的小朋友爱用表情来搞点事。第一次把当时那个表改为utf8mb4解决了,第二次说啥都不好使。网上找了半天,发现好多人不去实验一下就复制别人的代码网上发,然后导致我拿来用直接不行。最后一遍遍尝试终于解决了,防止以后再出错,总结下吧。我们的MYSQL数据库普遍用的字符集是UTF-8,默认情况下是utf8_general_ci,…

大家好,欢迎来到IT知识分享网。

吃了经验的亏,因为Emoji表情引起的项目bug被撸主遇到两次了,总有一些调皮的小朋友爱用表情来搞点事。第一次把当时那个表改为utf8mb4解决了,第二次说啥都不好使。网上找了半天,发现好多人不去实验一下就复制别人的代码网上发,然后导致我拿来用直接不行。最后一遍遍尝试终于解决了,防止以后再出错,总结下吧。

我们的MYSQL数据库普遍用的字符集是UTF-8,默认情况下是utf8_general_ci,这种字符集下,默认是支持1-3字节的编码,当然这对字母,汉字都是没啥问题的。但是对手机带的Emoji表情级不行了,因为它是4个字节的。

这里介绍处理的一些办法吧,主要有两个:

第一,修改数据库字符集:

这种方法需要的硬性要求就是你的mysql数据库版本5.5以后的。一般有数据库管理工具的,直接打开改了就是了,比如我用的HeidiSQL,直接把表改为utf8mb4就可以了。如图:

65fd7d52780e57042423e6d9c5e48229.png在默认字符集那里调整

1cb4a703cacb0ea3ed83e67243e5067b.png就可以了。

这种方法简单省事,但是可能需要重启数据库。还有个问题是,有时候这方法不太灵,我第一次用这个方法,完美解决的问题,但是第二次,说啥都不好使。所以,这种方式还是不推荐了。

第二,将这些表情过滤掉

既然数据库不能保存,那就直接把这些表情过滤掉好了。这种情况是损坏客户的个性而让服务更便捷的一张方式。目前很多网站就是这么干的,毕竟效率是关键,你这表情即便保存了,也说不定哪里再次用到,展示不了。

过滤这种事,简直太多坑,比如,我尝试了很多次的这种代码:

a69c3d63f120ff7b52fac5955ce5c8b9.png

撸主曾经十分坚信这就是最接近答案能解决表情问题的代码,即便不能,给他稍微改改就可以了。但是经过好多次,无论怎么搞,所有的字母和汉字全部都会给过滤成表情,最终还是没解决。哎,还是太年轻。

结果没办法,再去找别的代码,于是,碰到了正确的,也是目前最推荐的答案:

/*** emoji表情替换

*

*@paramsource 原字符串

*@paramslipStr emoji表情替换成的字符串

*@return过滤后的字符串*/

public staticString filterEmoji(String source,String slipStr) {if(StringUtils.isNotBlank(source)){return source.replaceAll(“[\\ud800\\udc00-\\udbff\\udfff\\ud800-\\udfff]”, slipStr);

}else{returnsource;

}

}

建议做成工具方法,方便实用,亲测可行。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/24630.html

(0)
上一篇 2023-03-03 15:00
下一篇 2023-04-11 11:00

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

关注微信