PHP用户连续签到赠送额外积分

2025-11-30 20:47:54

目录

一、需求

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