导航:首页 > 编程大全 > php表情存不进数据库

php表情存不进数据库

发布时间:2023-09-08 00:34:25

① 如何转义emoji表情,让它可以存入utf8的数据库

unicode emoji是4个字节的,存不进里,找到一个转义的库code.iamcal.com/php/emoji/,但是转为Unicode之后,还是4个字节,一样存不进,应该说根本没转。转为其他格式的emoji又怕以后新增了表情不好做,你们在不改数据库编码的前提下,是怎么弄的?
方法1:base_encode64
这种方法是可以,但是旧数据没有经过encode操作,取数据的时候如果统一进行decode的话,旧数据会丢失的。
方法2:urlencode
这个似乎可以,对没有经过encode的数据进行decode也不会有影响,而且多次decode似乎也不会有影响。你们说这个方法有缺陷吗?
=======================
一个发现,微信获取用户基本信息的时候,笑哭那个表情print_r出的是\ud83d\ude02,而我存储的时候,报错说这个 \xF0\x9F\x98\x82 值不能存储,请问这是怎么回事,自动转码了,转成的这是什么?是微信转码过了吗?
=======================
方法3:最后采用了下面采纳的那个方法,因为我觉得它有下面几个优点:
1、那个方法只转换表情,不会转换中文,所以数据还是直接可读的
数据库中存储起来是这样的, 后面的\ud83d\udca5可以随意复制粘贴,而显示出来是这样的,
2、不会把表情转换为其它标准,只有一个简单的,固定的转换算法,也就是说不需要一个表情库来对照着转换,所以以后其它人要使用这个数据的时候,也很容易知道每个表情是对应的哪个。就算苹果大爷又增加了表情,也不需要做什么额外的修改。
3、可以无限decode输出的都是正确的内容。因为有的时候可能需要在一次请求中的两个地方做decode,其它decode多次会把正确的数据改成其它数据,这个不会。

② php存入emoji表情出现乱码,数据库已经改为utf8mb4编码了依然乱码

你插入数据的时候写的insert中字段数据的编码不对。你要转换成相应的字符编码才可以的。
<?php
header("Content-type:text/html;charset=utf8");
//你的代码
//也可以用notepad++将文件格式改为UTF8
?>

插入数据库需要
1
mysql_query("SET NAMES UTF8");

阅读全文

与php表情存不进数据库相关的资料

热点内容
暑假编程培训怎么学 浏览:88
对商家怎么推广app 浏览:92
xplane10安卓破解 浏览:309
下载中国知网免费入口登入工具 浏览:959
台达编程软件如何下载安装 浏览:758
c程序设计试题汇编谭浩强pdf 浏览:28
任务栏出现的文件在哪里 浏览:119
房山网络大学如何报名 浏览:252
磊科无线路由器忘记用户名和密码 浏览:810
怎么快速建word文件夹 浏览:372
怎么把微信pdf文件发到qq邮箱 浏览:736
招标人在招标文件中公布的内容 浏览:793
数据库技术有哪些工程应用 浏览:471
如何将cad中的文字复制到word中 浏览:772
string转jsonjs 浏览:810
如何反制清洁网络计划 浏览:500
数据库数据库实例是什么意思 浏览:756
6splus南京东路苹果专卖店报价 浏览:688
vm获取配置文件中变量 浏览:639
三星note2哪个版本好 浏览:405

友情链接