乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      springboot+mysql程序插入微信表情(emoji)錯(cuò)誤

       quasiceo 2018-08-19

      在做項(xiàng)目的過(guò)程中要集成了微信登陸功能,當(dāng)通過(guò)微信登錄請(qǐng)求拿到用戶的個(gè)人信息后保存用戶帶有表情的昵稱時(shí)服務(wù)拋出了異常。

      程序報(bào)錯(cuò)圖片

      原因是原來(lái)的數(shù)據(jù)庫(kù)設(shè)置的字符格式(utf-8)不支持emoji表情字符。找到問(wèn)題后,通過(guò)查閱資料,發(fā)現(xiàn)只需要將數(shù)據(jù)的字符格式都設(shè)置為utfmb84即可解決。
      問(wèn)題的原因是數(shù)據(jù)庫(kù)中使用的字符編碼為UTF-8,這種編碼有可能是兩個(gè)、三個(gè)、四個(gè)字節(jié)。Emoji表情是4個(gè)字節(jié),而mysql的utf8編碼最多3個(gè)字節(jié),所以數(shù)據(jù)插不進(jìn)去,而utfmb64是支持四個(gè)字節(jié)的。所以解決方案就是:將mysql編碼從utf8轉(zhuǎn)換成utf8mb4。

      解決步驟:
      1.檢查使用的mysql數(shù)據(jù)庫(kù)的版本,數(shù)據(jù)庫(kù)版本需>=5.5.3版本。(因?yàn)槭褂玫氖莔aven打包,還檢查了mysql驅(qū)動(dòng)的jar包版本

      [client]
       default-character-set = utf8mb4
      [mysql]
      default-character-set = utf8mb4
      [mysqld]
       character-set-server = utf8mb4
       collation-server = utf8mb4_unicode_ci
       init_connect='SET NAMES utf8mb4'
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8

      3.重新啟動(dòng)mysql數(shù)據(jù)庫(kù)
      4 . 檢查字符集
      SHOW VARIABLES WHERE Variable_name LIKE ‘character_set_%’ OR Variable_name LIKE ‘collation%’;
      數(shù)據(jù)庫(kù)字符編碼集合
      5,存在的數(shù)據(jù)庫(kù)的字符集是utf8的,如果要支持utf8mb64則需要將已經(jīng)存在的數(shù)據(jù)庫(kù)、表、表字段類型修改成支持utf8mb64.

      修改數(shù)據(jù)庫(kù)字符集:

      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 column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
      • 1

      以上的操作如果使用navciat可視化工具也可以執(zhí)行。

      6,這步可有可無(wú),前提是如果使用到 spring boot的連接池,請(qǐng)?jiān)趕pring boot 的配置文件application.yml 設(shè)置連接使用utf8mb64

      spring.mysql.datasource.init-sql=SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci
      • 1

      (因?yàn)樵诒卷?xiàng)目中使用的druid數(shù)據(jù)源所以該配置無(wú)效沒有起到作用)

      7,設(shè)置連接驅(qū)動(dòng)的JDBC_URL

      修改如jdbc:mysql://localhost:3306/db?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&autoReconnect=true


      本次解決問(wèn)題心得

      出現(xiàn)問(wèn)題后將問(wèn)題拆解開來(lái),一段一段測(cè)試解決,數(shù)據(jù)插入時(shí)出現(xiàn)問(wèn)題,先看使用sql語(yǔ)言測(cè)試是否可以直接插入相同類型的數(shù)據(jù)到數(shù)據(jù)庫(kù),其次檢查是否是程序端出現(xiàn)了問(wèn)題。
      1.先確定直接使用sql語(yǔ)言可以將帶有emoji表情的字符串插入數(shù)據(jù)庫(kù)。
      插入后的數(shù)據(jù)
      (當(dāng)時(shí)數(shù)據(jù)插入成功后,在數(shù)據(jù)庫(kù)中表情字符所顯示的是?,但是前臺(tái)拿到數(shù)據(jù)可以正常的讀取為表情。)
      2.當(dāng)上一步驟可以成功操作后,基本上問(wèn)題就解決了。如果還是未解決,那么問(wèn)題就出現(xiàn)在程序這一端了,如果使用springboot,可以看到上面有一段程序配置application.yml配置將其加到配置中即可,如果使用的druid數(shù)據(jù)源,需要將其加入到druid配置中。

      本人是剛畢業(yè)的菜鳥,只是想將遇到的問(wèn)題記錄下來(lái)并且通過(guò)記錄去推動(dòng)自己思考和學(xué)習(xí),這些問(wèn)題根本的原因是什么,以及學(xué)習(xí)它所牽連的知識(shí)。
      如果對(duì)您有幫助,也是我的榮幸。

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類似文章 更多