当前位置: 首页 > news >正文

开发避坑指南(29):微信昵称特殊字符存储异常修复方案

异常信息

Cause: java.sql.SQLException: 
Incorrect string value: '\xF0\x9F\x8D\x8B\xE5\xBB...' for column 'nick_name' at row 1

在这里插入图片描述

异常背景

抽奖大转盘,抽奖后需要保存用户抽奖记录,用户再次进入游戏时根据抽奖记录判断剩余抽奖机会。保存抽奖记录时需要保存用户open_id,昵称,抽奖时间等信息,保存昵称时异常,没有成功记录抽奖导致剩余机会不减,用户可多次抽奖。

保存接口请求参数:
在这里插入图片描述

异常分析

昵称包含特殊字符,数据库定义的数据类型、字符集不支持,所以保存失败了。

解决办法

MySQL在5.5.3版本之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。低版本的MySQL

支持的utf8编码,最大字符长度为 3 字节,如果遇到 4 字节的字符就会出现错误了,其中Emoji表情是四个字节,导致插不进去。

解决这个办法可以从数据库层面上解决,即修改数据库的字段定义,如下方案1;或者从应用层面解决,如下方案2。

方案1:修改数据库字段字符集

mysql数据库中,将nick_name字段字符集由utf8修改为utf8mb4,数据库链接中将字符集由utf8改为utf8mb4。如下:

url: "jdbc:mysql://localhost:3306/big-turntable?useUnicode=true&characterEncoding=utf8mb4&useSSL=false"

查看日志和数据库,插入不再异常。

方案2:使用 Base64 编码与解码昵称

//Base64编码保存昵称
String nickname = record.getNickName();
if(stringutil.isNotEmpty(nickname)){nickname = Base64.getEncoder().encodeTostring(nickname.getBytes( charsetName: “utf-8));record.setNickName(nickname);
}   //Base64解码昵称
if(stringutil.isNotEmpty(record.getNickName())){String nickName =record.getNickName();String nickName = new String(Base64.getDecoder().decode(nickName), 	 charsetName: "UTF-8");nickNameMap.put(record.getPriceId(),nickName);
}
http://www.dtcms.com/a/340988.html

相关文章:

  • 0基础安卓逆向原理与实践:第5章:APK结构分析与解包
  • pinctrl和gpio子系统实验
  • 读者写者问题
  • 接地电阻柜的核心作用
  • postman+newman+jenkins接口自动化
  • Python 文件操作与异常处理全解析
  • 7.Kotlin的日期类
  • Flink实现Exactly-Once语义的完整技术分解
  • 自动驾驶导航信号使用方式调研
  • ABAP OOP革命:ALV报表面向对象改造深度实战
  • PiscCode使用MediaPipe Face Landmarker实现实时人脸特征点检测
  • Tomcat 性能优化终极指南
  • 从零开始学AI——13
  • 吴恩达 Machine Learning(Class 3)
  • MySQL 8.x的性能优化文档整理
  • JavaScript 性能优化实战(易懂版)
  • InfluxDB 查询性能优化实战(一)
  • 【PSINS工具箱】平面上的组合导航,观测量为位置、速度、航向角。附完整的MATLAB代码
  • sqli-labs通关笔记-第58关 GET字符型报错注入(单引号闭合 限制5次探测机会)
  • 六大缓存(Caching)策略揭秘:延迟与复杂性的完美平衡
  • git-git submodule和git subtree的使用方式
  • 大规模IP轮换对网站的影响(服务器压力、风控)
  • CISP-PTE之路--05文
  • 企业微信2025年发布会新功能解读:企业微信AI——2025年企业协作的「最优解」是如何炼成的?
  • 跨境电商独立站搭建多少钱?响应式设计 + 全球 CDN 加速服务
  • IBMS系统集成平台具备哪些管理优势?核心价值体现在哪里?
  • HTTP/1.1 与 HTTP/2 全面对比:性能革命的深度解析
  • 工控PID控制器学习总结
  • [element-plus] el-tree 拖拽到其他地方,不拖拽到树上
  • 怎么确定mongodb是不是链接上了?