目录
一、需求
1、为什么要赠送积分
2、怎么获取积分
3、积分如何使用
1)、兑换
2)、抵扣
3)、等等
二、规则
1、用户注册
2、成功邀请新用户
3、用户签到
4、联想
三、数据表
1、用户表 user
2、用户签到表 user_sign
3、积分(获取)日志表 integral_log
四、代码
1、用户签到方法
2、公共类 - 积分赠送日志方法
一、需求
1、为什么要赠送积分
用户(连续)签到赠送(额外)积分,可以增加用户的活跃度,少一些僵尸用户;邀请好友赠送积分,可以扩大平台的用户量。
2、怎么获取积分
这个范围就比较广了,给几个获取积分的例子
用户注册获取积分
成功邀请新用户获取积分
完成首购获取积分
用户消费获取积分
用户签到获取积分
完成新手任务获取积分
完善基本信息获取积分
…
3、积分如何使用
1)、兑换
可以弄个积分商城,直接用积分兑换商品
2)、抵扣
购买商品时,除了可以使用优惠券抵扣、余额抵扣,还可以使用积分抵扣
3)、等等
二、规则
1、用户注册
用户注册赠送积分
2、成功邀请新用户
成功邀请新用户,新用户有注册积分,邀请人有邀请积分
3、用户签到
用户每日签到可以获取固定的积分
用户连续签到满n天,额外赠送积分
如果用户同时满足多个连续签到任务,则取额外积分为最大签到天数的积分
多个签到任务:比如用户连续5天赠送1积分,用户连续签到10天赠送2积分;用户连续签到了10天,则既满足连续签到5天,又满足连续签到10天,我们取连续签到10天的2积分作为额外积分。(也可以都取,则额外积分为1+2=3,这个要看规则怎么定了)
4、联想
可以添加规则用户签到当天如果是用户生日,积分翻倍
Tips:如果生日可为公历,也可为农历,则要注意区分
…
三、数据表
1、用户表 user
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID', ... `integral` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '总积分', `signDay` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '连续签到天数', `createTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间', `updateTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
2、用户签到表 user_sign
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID', `userId` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户ID', `integral` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '积分', `dateTime` varchar(50) NOT NULL DEFAULT '' COMMENT '签到日期:格式为2090-01-01', `remark` text COMMENT '备注', `createTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间', `updateTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
3、积分(获取)日志表 integral_log
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键ID', `userId` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '用户ID', `fkId` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '关联id', `fkType` int(1) unsigned NOT NULL DEFAULT '0' COMMENT '关联类型:1:新用户注册;2用户签到;3用户消费;4邀请新用户;...', `integral` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '积分', `remark` text COMMENT '备注', `createTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间', `updateTime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
四、代码
1、用户签到方法
/** * 用户签到 * @return mixed * @throws Exception */ public function sign() { $userInfo = self::loginInfo(); //缓存中根据Token获取用户的登录信息 if (!$userInfo){ exit('请先登录'); } $userId = $userInfo['id']; $userDao = new UserDao(); //实例化用户表 $signDao = new UserSignDao(); //实例化用户签到表 //判断用户今天是否签到 $dateTime = date('Y-m-d'); $todayParam = ['userId' => $userId, 'dateTime' => $dateTime]; $todayInfo = $signDao->single($todayParam); if ($todayInfo){ exit('您今天已经签到过了'); } //判断用户昨天是否签到 $yesterday = date('Y-m-d', strtotime('-1 day')); //昨天的日期格式:2090-01-01 $yesterdayParam = ['userId' => $userId, 'dateTime' => $yesterday]; $yesterdayInfo = $signDao->single($yesterdayParam); if ($yesterdayInfo){ //昨天签到了,签到天数自增1 $userDao->setInc(['id' => $userId], 'signDay', 1); //第三个参数默认为1,可以不传。 }else{ //昨天断签,连续签到天数重置为1 $userDao->updateByQuery(['signDay' => 1], ['id' => $userId]); //更新该用户的签到天数为1天 } list($integral, $remark) = IntegralService::insert($userId, 2); //记录签到积分日志 //添加签到数据 $data = [ 'userId' => $userId, //用户ID 'dateTime' => $dateTime, //签到日期 'integral' => $integral, //签到赠送的积分 'remark' => $remark //签到日志 ]; $signDao->insert($data); //添加数据,createTime,updateTime已在该方法中追加 return 'success'; }
2、公共类 - 积分赠送日志方法
这个表可以再加个type字段,区分积分类型:积分获取/积分消费
class IntegralService{ /** * [积分赠送日志]公共方法 * @param $userId 用户ID * @param $fkType 赠送类型:1:新用户注册;2用户签到;3用户消费;4邀请新用户;... * @param int $fkId 关联ID:如果类型为用户消费,则关联ID为订单的ID;如果类型为邀请新用户,则关联ID为新用户的ID... * @return array 返回[积分,备注] */ public static function insert($userId, $fkType, $fkId = 0){ $remark = ''; $integral = 0; $userDao = new UserDao(); if ($fkType == 1){ //新用户注册 $integral = 20; //新用户注册赠送积分:这个可以写到配置里 $remark = '新用户赠送积分'; }else if ($fkType == 2){ //每日签到赠送额外积分 list($integral, $remark) = self::userSign($userId, $userDao); }else if ($fkType == 3){ //消费 //... }else if ($fkType == 4){ //推荐新用户 $userInfo = $userDao->info($fkId); //新用户的ID if (empty($userInfo)){ exit('被邀请用户不存在'); } $integral = 10; //推荐新用户注册赠送积分:这个可以写到配置里 $remark = '邀请新用户 [ ' . $userInfo['username'] . ' ] 赠送积分'; } //积分日志记录 $data = [ 'userId' => $userId, 'fkId' => $fkId, 'fkType' => $fkType, 'integral' => $integral, 'remark' => $remark ]; $integralDao = new IntegralLogDao(); $integralDao->insert($data); //添加数据,createTime,updateTime已在该方法中追加 //用户积分自增$integral $userDao->setInc(['id' => $userId], 'integral', $integral); return [$integral, $remark]; } /** * 获取会员签到获取的积分,备注 * @param $userId * @param $userDao * @return array */ public static function userSign($userId, $userDao){ $userInfo = $userDao->info($userId); if (empty($userInfo)){ exit('用户不存在'); } $signDay = $userInfo['signDay']; //用户连续签到天数 $remark = ''; $integral = 3; //用户每日签到积分:这个可以写到配置里 if ($signDay != 0){ //如果签到日期不为0 # 签到额外送积分:这个可以写到配置里 /** * name:说明 * desc:备注,这里表示连续签到天数 * value:值,这里表示额外赠送积分数量 */ $extraIntegral = [ ['name' => '连续签到7天额外赠送1积分', 'desc' => 7, 'value' => 1], ['name' => '连续签到15天额外赠送2积分', 'desc' => 15, 'value' => 2], ['name' => '连续签到30天额外赠送5积分', 'desc' => 30, 'value' => 5], ]; //二维数组排序:按照积分降序,如果同时满足多个连续签到任务,则取最大签到天数的积分。 $values = array_column($extraIntegral, 'value'); array_multisort($values, SORT_DESC, $extraIntegral); $isGiveExtra = false; //是否已经赠送了额外积分 foreach ($extraIntegral as $value){ $day = $value['desc']; //配置的签到天数 $giveIntegral = $value['value']; //赠送额外积分 if (($signDay % $day) == 0){ //如果:用户连续签到天数 % 配置的连续签到天数 = 0;我们认为该用户可以获取额外积分 if ($isGiveExtra){ //如果:已经赠送了额外积分,则不再赠送,结束循环 break; } $integral += $giveIntegral; //积分 = 每日签到默认积分 + 连续签到额外赠送的积分 $remark = "您已经连续签到了 [ {$day} ] 天,额外赠送您 [ {$giveIntegral} ] 积分"; //备注 $isGiveExtra = true; //设置为true,已经赠送了积分,不再重复赠送 # 或者去除 $isGiveExtra 变量相关操作,直接在这里 break } } } $remark = $remark ? $remark : '签到赠送积分'; return [$integral, $remark]; } }
版权声明:本文为CSDN博主「꧁❦༺东伯༒雪鹰༻❦꧂」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_36025814/article/details/107078614