在帝国cms中如果发布的内容中包含了emoji表情,保存的时候会出错。如果我们想保留emoji表情,要怎么处理呢?今天,小编教大家如何实现这个功能。含有emoji表情的字符串在MySQL中的储存,MySQL中要使用utf8mb4字符集。PHP需要对字符串进行base64编码,从数据库中取出时再对字符串进行解码。下面我们以后台资讯表标题支持emoji表情为例来讲解。具体操作如下:
1.首先要配置数据库支持emoji表情 修改帝国cms的配置文件:/e/config/config.php,将编码改为:utf8mb4
$ecms_config['db']['setchar']='utf8mb4'; //设置默认编码
$ecms_config['db']['dbchar']='utf8mb4'; //数据库默认编码
2.在/e/class/userfun.php中添加接受emoji表情,解析emoji表情的函数,代码如下:
//接受emoji表情
function addEmoji($content){
$return= preg_replace_callback('/[\xf0-\xf7].{3}/', function ($r){return '@E' . base64_encode($r[0]);}, $content);
return $return;
}
//解析emoji表情
function getEmoji($content){
$return=preg_replace_callback('/@E(.{6}==)/',function ($r){return base64_decode($r[1]);},$content);
return $return;
}
3.在/e/class/functions.php中,找到返回自定义字段函数ReturnAddF 大概6179行 添加如下代码:
if($f=='newstime')//时间
{
$value=empty($value)?time():to_time($value);
}
elseif($f=='title'){
$value=addEmoji($value);
}
4.在内容模板中解析标题中的emoji表情,代码如下:
<?=getEmoji($navinfor['title'])?>
最终整合后效果图如下: