首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  程序员

Thinkphp3 从数据库读取 “𬭶”“𬬻”“𬭸”“𫟷”和所有 emoji 全部显示两个问号,编码是 utf8

  •  
  •   l890908 · 20 天前 · 1553 次点击
    数据库编码是 utf8mb4_general_ci

    ThinkPHP3 编码配置为默认的 utf8,其他中文字英文都能从数据库都去并显示正确,唯独这些偏僻字显示两个??,emoji 也无法识别显示一个??,按道理 utf8mb4_general_ci 应该是都可以识别的

    可能是啥原因?
    13 回复  |  直到 2019-11-18 09:09:07 +08:00
        1
    vibbow   20 天前
    你连接用的编码呢?
        2
    wangyzj   20 天前
    把 ThinkPHP3 编码配置改为 utf8mb4_general_ci
        3
    l890908   20 天前
    @vibbow 连接编码是默认的 utf8 -》'DB_CHARSET' => 'utf8', // 数据库编码默认采用 utf8
    输出编码也是 utf-8 'DEFAULT_CHARSET' => 'utf-8', // 默认输出编码
        4
    l890908   20 天前
    @wangyzj 这样不行,设置成 utf8mb4 就所有中文都是乱码了
        5
    renmu   20 天前 via Android
    随便提个猜想,机器字体不支持
        6
    also24   20 天前
    『数据库编码是 utf8mb4_general_ci 』

    是否有检查具体的表和字段的编码?
        7
    vibbow   20 天前
    连接编码需要是 utf8mb4
        8
    wangyzj   20 天前
    @l890908 不应该
    理论上可以转换的
        9
    mamahaha   20 天前
    皮裤套棉裤,必定有缘故
        10
    heart4lor   20 天前
    数据库、表、字段、连接编码都用 utf8mb4
        11
    vjnjc   19 天前
    你要 connection 使用 utf8mb4 才能正确读出 emoj,所以要把编码改成 utf8mb4,在这个基础上解决问题。

    我怀疑是你以前用了 utf8 写入了大部分数据,使得他没法用 utf8mb4 的方式读出来,那么你把所有数据洗一下吧(只是一个猜测
        12
    l890908   19 天前
    @vjnjc 是 写入 utf8mb4, 然后用其他编码是读不出来的,得吧所有数据洗一遍,还不能重新建表插入
        13
    qsbaq   19 天前
    utf8mb4 正解
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2245 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 27ms · UTC 10:34 · PVG 18:34 · LAX 02:34 · JFK 05:34
    ♥ Do have faith in what you're doing.