PHP 做微信二次开发,获取基本信息用户名中含有 Emoji 表情导致写入数据库出错,求解决方案 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
hrbwaxdoll
V2EX    微信

PHP 做微信二次开发,获取基本信息用户名中含有 Emoji 表情导致写入数据库出错,求解决方案

  •  
  •   hrbwaxdoll 2015-04-08 16:38:23 +08:00 5162 次点击
    这是一个创建于 3913 天前的主题,其中的信息可能已经有所发展或是发生改变。

    RT,感谢

    12 条回复    2015-04-27 19:40:55 +08:00
    shiny
        1
    shiny  
    PRO
       2015-04-08 16:39:04 +08:00   1
    charset 设置为 utf8mb4
    hrbwaxdoll
        2
    hrbwaxdoll  
    OP
       2015-04-08 16:40:19 +08:00
    已有的数据库,CentOS+Mysql,如何修改?刚刚有在其它地方搜索到这个方法,但试了半天无果啊。
    anewg
        3
    anewg  
       2015-04-08 16:46:42 +08:00   1
    lxrmido
        4
    lxrmido  
       2015-04-08 16:46:58 +08:00
    遇上这个问题的时候,我用urlencode临时解决了……
    alex321
        5
    alex321  
       2015-04-08 16:48:36 +08:00
    我用了 base64。。。反正我这里不用按照用户昵称检索。。
    abelyao
        6
    abelyao  
       2015-04-08 17:24:59 +08:00
    @Livid 大大曾发过一个帖子 /t/137724
    pubby
        7
    pubby  
       2015-04-08 17:32:20 +08:00
    不需要作为查询条件的话就用一些转换的办法,比如json_encode() 后存就绕开了
    hrbwaxdoll
        8
    hrbwaxdoll  
    OP
       2015-04-08 17:50:19 +08:00
    我也不按用户昵称检索,感谢楼下各位,晚上试一下,再来表示感谢。
    raincious
        9
    raincious  
       2015-04-08 18:00:25 +08:00
    @hrbwaxdoll

    PHP+MySQL的话,一楼的方式是最优解,除非你已经有了大量数据,进行编码切换完全不可能的时候。

    编码转换:
    http://stackoverflow.com/questions/6115612/how-to-convert-an-entire-mysql-database-characterset-and-collation-to-utf-8
    (操作前先备份)
    hrbwaxdoll
        10
    hrbwaxdoll  
    OP
       2015-04-08 22:30:25 +08:00
    @raincious 转换为一楼的格式会不会有其它未知影响?
    @pubby 显示的时候还能显示成图标吗?
    @abelyao 感谢~~~!
    @anewg 已用这个临时解决,然后查询更好的方法,十分感谢。
    @shiny 十分感谢
    raincious
        11
    raincious  
       2015-04-08 23:06:06 +08:00   1
    @hrbwaxdoll

    刚又搜索了下:
    http://dba.stackexchange.com/questions/8239/how-to-easily-convert-utf8-tables-to-utf8mb4-in-mysql-5-5

    里面提到
    > Note, however, that you cannot fully automate the conversion from utf8 to utf8mb4.

    虽然这个答案没被接受,但楼主最好还是备份一个冷的下来按照上面链接里提到的要点和自己项目的状况做测试,看是否会造成问题,这样也最稳妥。

    当然,有的时候最优解也有无法使用的时候,这个时候就只能按照楼上们的说法进行储存时和读取时转换了。
    konakona
        12
    konakona  
       2015-04-27 19:40:55 +08:00
    我想知道可不可以(大部分gbk)某一表(如message)utf8mb4然後完美支持表情呢?

    我在在本做了的,但是效果有出呢...
    关于     帮助文档     自助推广系统     博客/a>     API     FAQ     Solana     4872 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 41ms UTC 03:55 PVG 11:55 LAX 19:55 JFK 22:55
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86