问题描述
输入法输入表情或特殊符号,存入数据库时,会发现有报错,因为UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而MySQL的utf8编码最多3个字节,所以数据插不进去。
解决方法
前端处理方法
思路使用正则匹配特殊符号或表情进行过滤,如下(根据自己的需求调整):
// 使用正则检查输入值是否包含表情符号 checkEmoji(inputValue){const emojiPattern = /[\uD83C[\uDF00-\uDFFF]|\uD83D[\uDC00-\uDE4F]/; const hasEmoji = emojiPattern.test(inputValue); console.log('是否包含表情符号',hasEmoji);},// 过滤特殊符号checkSymbol(inputValue){console.log('前端过滤特殊符号');const specialSymbol = /[`~!@#$%^&*()+=|{}':;',/\/\[\].<>/?~!@#¥%……&*()——+|{}【】‘;:”“’。,、?]/ const hasSymbol = specialSymbol.test(inputValue)console.log('是否包含特殊符号',hasSymbol);}
后端处理方法
后端存入数据库的时候,将Mysql的编码从utf8转换成utf8mb4