問題分析
在微信開發過程中,總是會遇到帶有emoji表情昵稱的微信用戶無法自動登錄的問題。
后台代碼拋出類似下面的異常信息。
java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for colum n 'name' at row 1
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2620)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1662)
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1581)
原來emoji表情是占4個字節的,但是在MySQL中UTF-8字符只是占3個字節,這就導致MySQL數據庫無法保存emoji表情了。
解決方法
既然知道了原因,那么解決方法也就產生了。
只要讓MySQL的字符占4個字節就成了。恰好MySQL5.5.3 以后的版本都有 utf8mb4 這種字符集,它每個字符占4個字節,滿足保存emoji表情的需要。
現在目標是將MySQL數據庫有原來的字符集修改為 utf8mb4。
1. 修改數據庫、表、列的字符集
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE table_name CHANGE column_name VARCHAR(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
2. 修改MySQL配置文件 my.cnf(windows下是 my.ini)
[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'
注意: 如果后台代碼使用了 mysql-connector-x.x.x.jar ,那么mysql-connector的版本必須高於 5.1.13 ,否則不支持 utf8mb4。
參考這篇博客 mysql保存emoji表情(微信開發用戶昵稱..)