在開發(fā)微信開放平臺, 接入微信公眾號的數(shù)據(jù)時, 關(guān)于用戶的nickname和文本消息是,大量出現(xiàn)emoji的文本信息, 超時了utf-8字符集的存儲范圍
站在用戶的角度思考問題,與客戶深入溝通,找到鹽津網(wǎng)站設(shè)計與鹽津網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都做網(wǎng)站、網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、申請域名、網(wǎng)頁空間、企業(yè)郵箱。業(yè)務(wù)覆蓋鹽津地區(qū)。
在存儲數(shù)據(jù)時, 出現(xiàn)部分特殊字符存儲字符串失敗.
查閱MySQL官方文檔時,給出如下支持utf8轉(zhuǎn)utf8mb4的官方處理辦法
https://dev.mysql.com/doc/refman/5.7/en/charset-unicode-conversion.html
上述的步驟只是針對server端的配置.
因為我目前的項目, 使用的是JAVA編寫, 使用JDBC連接操作數(shù)據(jù)庫, 如下針對的JDBC操作的解決方案
JDBC的URL之前的配置方式
String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=UTF-8";
在連接配置中,聲明UTF-8的字符編碼,在目前的存儲需求上來講,在存儲emoji字符串時會報錯. 就算服務(wù)端的數(shù)據(jù)庫設(shè)置了utf8mb4字符集類型
客戶端修改成如下配置
String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=utf8mb4";
客戶端連接時報錯,不支持該字符集
連接配置改成
String url = "jdbc:mysql://HOST:PORT/DATABASE";
同時數(shù)據(jù)庫配置文件my.cnf 進行相應(yīng)的修改
[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
重啟服務(wù)MySQL服務(wù)
問題到此解決