推送内容如果包含了emoji表情,需要做以下修改
1 mysql 要用5.5.3以上
版本(如果不能升级,请用base64保存,推送时再转码)
2 将表和推送内容表字段修改成utf8mb4_unicode_ci
编码格式(不需要改系统的my.cnf,也不需要
重启mysql)
如果用了apnsphp来推送,可能依然会出现发送emoji表情变成?的问题:
请找到Message.php的getPayload方法,在convert转码判断上加上"false &&"禁止执行。因为这段代码会将部分emoji表情截断。
class="java">
if (false && !defined('JSON_UNESCAPED_UNICODE') && function_exists('mb_convert_encoding')) {
$sJSON = preg_replace_callback(
'~\\\\u([0-9a-f]{4})~i',
create_function('$aMatches', 'return mb_convert_encoding(pack("H*", $aMatches[1]), "UTF-8", "UTF-16");'),
$sJSON);
}
至此,就解决问题了。
参考:
apnsphp截断发送内容导致emoji显示失效的问题:
https://github.com/iamcal/php-emoji/issues/8
emoji 编码表:
http://apps.timwhitlock.info/emoji/tables/unicode#
mysql 支持utf8mb4:
https://my.oschina.net/wingyiu/blog/153357