打印 上一主题 下一主题

Discuz新添加功能 广告到期提醒

跳转到指定楼层
楼主
SetYun 发表于 2018-10-20 10:17:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
X2.0中添加广告到期提醒的新功能

后台设置在 运营--站点广告--设置 中设置



可以设置是否开启广告提醒,到期前多少天提醒,提醒的方式,以及提醒的用户(填用户名)。

提示:如果到期前多少天提醒和提醒的用户留空,则自动关闭该功能,但提醒的用户实际不存在也会开启该功能,因此请填入正确的用户名(注意分行)。

保存设置后以序列化的形式存储在common_setting表中的skey为advexpiration的值里,如下:

  • a:4:{s:5:"allow";b:1;s:3:"day";s:1:"1";s:6:"method";a:2:{i:0;s:5:"email";i:1;s:6:"notice";}s:5:"users";s:5:"admin";}

当我们设置了广告提醒之后,会在每日执行的清除数据的脚本cron_cleanup_daily.php中被执行

具体执行的代码如下:
  • if(!empty($_G['setting']['advexpiration']['allow'])) {
  • $endtimenotice = mktime(0, 0, 0, date('m', TIMESTAMP), date('d', TIMESTAMP), date('Y', TIMESTAMP)) + $_G['setting']['advexpiration']['day'] * 86400;
  • $query = DB::query("SELECT advid, title FROM ".DB::table('common_advertisement')." WHERE endtime='$endtimenotice'");
  • $advs = array();
  • while($adv = DB::fetch($query)) {
  • $advs[] = ''.$adv['title'].'';
  • }
  • if($advs) {
  • $users = explode("", $_G['setting']['advexpiration']['users']);
  • $users = array_map('trim', $users);
  • if($users) {
  • $query = DB::query("SELECT username, uid, email FROM ".DB::table("common_member")." WHERE username IN (".dimplode($users).")");
  • while($member = DB::fetch($query)) {
  • $noticelang = array('day' => $_G['setting']['advexpiration']['day'], 'advs' => implode("
    ", $advs));
  • if(in_array('notice', $_G['setting']['advexpiration']['method'])) {
  • notification_add($member['uid'], 'system', 'system_adv_expiration', $noticelang, 1);
  • }
  • if(in_array('mail', $_G['setting']['advexpiration']['method'])) {
  • sendmail("$member[username] <$member[email]>", lang('email', 'adv_expiration_subject', $noticelang), lang('email', 'adv_expiration_message', $noticelang));
  • }
  • }
  • }
  • }
  • }

代码首先判断了广告过期时间是否为设定的过期提醒时间,到common_advertisement表里取对应的数据,然后根据提醒用户取对应用户的信息,最后根据设定的提醒方式发送提醒或者邮件

该功能的推出让广告管理更加人性化,方便站长对各个广告的排期进行管理。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|SetYun ( 辽ICP备16005250号

GMT+8, 2024-12-22 00:56 , Processed in 0.036365 second(s), 5 queries , File On.

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表