IOS输入的emoji mysql存储不了(线上不能改utf8mb4),如何判断输入的字符含有emoji,然后提示
回复内容:
IOS输入的emoji mysql存储不了(线上不能改utf8mb4),如何判断输入的字符含有emoji,然后提示
不用判断是否是emoji,传输过来的用json_encode加密之后存入数据库,然后取出的时候用json_decode一下显示出来就可以了,json_decode之前也可以urlencode一下,取出的时候urldecode一下;
存入数据库之前
<code>$message = json_encode($message);</code>
取出之后
<code>$message = json_decode($message)</code>
code:
<code class="php">$regex = '/([0-9|#][\x{20E3}])|[\x{00ae}|\x{00a9}|\x{203C}|\x{2047}|\x{2048}|\x{2049}|\x{3030}|\x{303D}|\x{2139}|\x{2122}|\x{3297}|\x{3299}][\x{FE00}-\x{FEFF}]?|[\x{2190}-\x{21FF}][\x{FE00}-\x{FEFF}]?|[\x{2300}-\x{23FF}][\x{FE00}-\x{FEFF}]?|[\x{2460}-\x{24FF}][\x{FE00}-\x{FEFF}]?|[\x{25A0}-\x{25FF}][\x{FE00}-\x{FEFF}]?|[\x{2600}-\x{27BF}][\x{FE00}-\x{FEFF}]?|[\x{2900}-\x{297F}][\x{FE00}-\x{FEFF}]?|[\x{2B00}-\x{2BF0}][\x{FE00}-\x{FEFF}]?|[\x{1F000}-\x{1F6FF}][\x{FE00}-\x{FEFF}]?/u';var_dump(preg_match($regex, '?'));var_dump(preg_match($regex, '?'));var_dump(preg_match($regex, '?'));var_dump(preg_match($regex, '测试'));var_dump(preg_match($regex, 'hello, world'));var_dump(preg_match($regex, 'testing'));var_dump(preg_match($regex, '中文 English'));</code>
result:
<code>int(1)int(1)int(1)int(0)int(0)int(0)int(0)</code>
表达式是找来的,可以去看下utf8的码表中emoji的范围(或者从unicode码表范围转utf8)
不过建议还是改utf8mb4,这种迁移基本是无痛的,充分测试下即可
根本解决办
本&文来源gaodai^.ma#com搞#代!码网
搞gaodaima代码法是数据库支持emoji
你确定不把emoji存入数据库,而是检测到然后提示?
检测
<code>//返回true就表示有emojifunction testEmoji($str){ $text = json_encode($str); //暴露出unicode return preg_match("/(\\\u[ed][0-9a-f]{3})/i",$text);}</code>
转义并存入数据库
看我以前的问题吧 http://segmentfault.com/q/1010000003711491