微信昵稱含中文、特殊字符、emoji表情亂碼的后臺(tái)解決方案

前言

使用微信授權(quán)進(jìn)行系統(tǒng)登錄,授權(quán)登錄成功后,將微信與系統(tǒng)賬號進(jìn)行綁定,在個(gè)人中心需要顯示出綁定微信的昵稱、頭像等信息。但在聯(lián)調(diào)中發(fā)現(xiàn),當(dāng)昵稱中出現(xiàn)中文、特殊字符以及emoji表情的時(shí)候,會(huì)出現(xiàn)亂碼的問題。在網(wǎng)上查閱了許久的教程,要么答非所問,要么不夠完整有所缺失,通過反復(fù)嘗試驗(yàn)證,終于完美解決,故把自己解決方案分享給大家。

踩坑點(diǎn)說明

1、微信userinfo接口返回的用戶信息編碼格式并不是UTF-8,而是ISO-8859-1,這點(diǎn)在微信開放平臺(tái)上并沒有明確的說明,巨坑?。。?br> 2、不同的數(shù)據(jù)庫對于emoji的支持方式可能會(huì)不一致,比如mysql可設(shè)置數(shù)據(jù)庫編碼方式為utf8mb4,sql server可設(shè)置字段類型為nvarchar等。

前置條件

項(xiàng)目使用的sql server,需要先將保存用戶昵稱的字段類型設(shè)置為nvarchar,因?yàn)関archar并不支持Unicode編碼格式的數(shù)據(jù)。

保存數(shù)據(jù)

// 調(diào)用微信接口獲取用戶信息
String url = "https://api.weixin.qq.com/sns/userinfo?access_token=" + access_token + "&openid=" + openid + "&lang=zh_CN";

// 得到微信響應(yīng)結(jié)果
String result = restTemplate.getForObject(url, String.class);

// 將微信返回字符串進(jìn)行ISO-8859-1解碼,并編碼為UTF-8類型
result = new String(result.getBytes("ISO-8859-1"), "UTF-8");

// 使用fastjson將結(jié)果轉(zhuǎn)化為json對象
JSONObject jsonObject = JSON.parseObject(result);

// 將昵稱進(jìn)行UrlEncoder編碼
String nickName = URLEncoder.encode(jsonObject.getString("nickname"),"UTF-8");

// 將昵稱存入數(shù)據(jù)庫即可
....

取出數(shù)據(jù)

URLDecoder.decode(nickName, "UTF-8")
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容