Heim > Backend-Entwicklung > PHP-Tutorial > mysql存入emoji表情现在为?

mysql存入emoji表情现在为?

WBOY
Freigeben: 2016-06-23 13:44:28
Original
1408 Leute haben es durchsucht

mysql存入emoji表情现在为???.按网上的说法把mysql的字符集改为utf8mb4,还是无效,显示为乱码。。请问有人遇到过吗?


回复讨论(解决方案)

emoji 表情是扩展的 utf-16 编码
你可以贴出含有 emoji表情 的文字的 base64 编码串
看看能否帮你解决问题

emoji 表情是扩展的 utf-16 编码
你可以贴出含有 emoji表情 的文字的 base64 编码串
看看能否帮你解决问题


这个就是表情base64位保存后的数据。8J+YhPCfmIM= 。版*烦看看!.现在好多应用都支持这个表情输入,就是不知道怎么保存的。

应该说改用 utf8mb4 字符集就可以了,不知道你为什么不行
考虑到文字中 emoji 字符并不多,可以用正则替换一下在存入

$text = base64_decode('8J+YhPCfmIM=');echo $text = preg_replace_callback('/[\xf0-\xf7].{3}/', function($r) { return '@E' . base64_encode($r[0]);}, $text);
Nach dem Login kopieren
Nach dem Login kopieren
@E8J+YhA==@E8J+Ygw==

都会后逆转换一下就可以了
$s = preg_replace_callback('/@E(.{6}==)/', function($r) {return base64_decode($r[1]);}, '@E8J+YhA==@E8J+Ygw==');var_dump(base64_decode('8J+YhPCfmIM=') == $s);
Nach dem Login kopieren
Nach dem Login kopieren
bool(true)

应该说改用 utf8mb4 字符集就可以了,不知道你为什么不行
考虑到文字中 emoji 字符并不多,可以用正则替换一下在存入

$text = base64_decode('8J+YhPCfmIM=');echo $text = preg_replace_callback('/[\xf0-\xf7].{3}/', function($r) { return '@E' . base64_encode($r[0]);}, $text);
Nach dem Login kopieren
Nach dem Login kopieren
@E8J+YhA==@E8J+Ygw==

都会后逆转换一下就可以了
$s = preg_replace_callback('/@E(.{6}==)/', function($r) {return base64_decode($r[1]);}, '@E8J+YhA==@E8J+Ygw==');var_dump(base64_decode('8J+YhPCfmIM=') == $s);
Nach dem Login kopieren
Nach dem Login kopieren
bool(true)


是啊,很郁闷。网上都说只要设置为utf8mb4 就行,可我的就不行。mysql的版本是用的是5.6的。。。。,wampserver环境。会不会是环境问题?

楼主,我也遇到相同的问题了,请问你最后怎么解决的?

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage