问题描述
输入法输入表情或特殊符号,存入数据库时,会发现有报错,因为UTF-8编码有可能是两个、三个、四个字节。Emoji表情是4个字节,而MySQL的utf8编码最多3个字节,所以数据插不进去。
解决方法
前端处理方法
思路使用正则匹配特殊符号或表情进行过滤,如下(根据自己的需求调整):
javascript
// 使用正则检查输入值是否包含表情符号
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