用wangEditor.js插件编写包含表情保存到mysql的时候出现报错:
Cause: java.sql.SQLException: Incorrect string value: 'xF0x9Fx98x86<b...' for column 'content' at row 1
解决方法之一:
因为一般情况下是公司内部用的管理系统,基本上不会用到表情 可以去掉 在wangEditor.js默认菜单配置中去掉emoticon元素就可以了
// 默认菜单配置 修改前
menus: ['head', 'bold', 'italic', 'underline', 'strikeThrough', 'foreColor', 'backColor', 'link', 'list', 'justify', 'quote', 'emoticon', 'image', 'table', 'video', 'code', 'undo', 'redo'],
// 默认菜单配置 修改后
menus: ['head', 'bold', 'italic', 'underline', 'strikeThrough', 'foreColor', 'backColor', 'link', 'list', 'justify', 'quote', 'image', 'table', 'video', 'code', 'undo', 'redo'],
解决方法之二:
更改以下 mysql配置文件 并重启mysql
[mysqld]
collation-server=utf8mb4_general_ci
character_set_server=utf8mb4
alter table notice character set utf8mb4;
原因: MySQL的utf8编码最多3个字节,Emoji表情或者某些特殊字符是4个字节,所以数据插入不了,需要修改编码。
在MySQL 的“utf8”实际上不是真正的 UTF-8。
“utf8”只支持每个字符最多三个字节,而真正的 UTF-8 是每个字符最多四个字节。
MySQL 一直没有修复这个 bug,他们在 2010 年发布了一个叫作“utf8mb4”的字符集,绕过了这个问题。
重启mysq只能对之后的生效 那之前的怎么办呢?
修改表的编码
alter table 表名 character set utf8mb4;
修改表中字段的编码
ALTER TABLE 表名
MODIFY COLUMN 字段 字段类型 CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL COMMENT '内容';
如果出现:Unknown collation: 'utf8mb4_0900_ai_ci' 问题 可能是mysql版本过低 用
ALTER TABLE 表名
MODIFY COLUMN 字段 字段类型 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL COMMENT '内容'
wangEditor.js插件地址