php 判断用户连续签到_使用PHP来查询连续签到的统计

05c7dcae9a960c747d5baa6b0c643aa0.pngCREATE TABLE `xcxmall_lepin_receive_activity` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`type` varchar(255) CHARACTER SET utf8 DEFAULT "",

`type_name` varchar(255) DEFAULT "",

`user_id` int(10) DEFAULT NULL,

`store_id` int(10) DEFAULT NULL,

`date` date DEFAULT NULL,

`addtime` int(11) DEFAULT NULL,

`money` decimal(10,2) DEFAULT "0.00",

`order_no` varchar(255) DEFAULT "",

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=145 DEFAULT CHARSET=utf8mb4;

上面是对应的数据库表

INSERT INTO `xl-pp`.`xcxmall_lepin_receive_activity`(`id`, `type`, `type_name`, `user_id`, `store_id`, `date`, `addtime`, `money`, `order_no`) VALUES (125, "percent2", "满券", 435, 4, "2020-06-06", 1590659535, 0.00, "");

INSERT INTO `xl-pp`.`xcxmall_lepin_receive_activity`(`id`, `type`, `type_name`, `user_id`, `store_id`, `date`, `addtime`, `money`, `order_no`) VALUES (126, "percent1", "0.5元红包", 433, 4, "2020-06-02", 1590659539, 0.50, "PA202005280552199335");

INSERT INTO `xl-pp`.`xcxmall_lepin_receive_activity`(`id`, `type`, `type_name`, `user_id`, `store_id`, `date`, `addtime`, `money`, `order_no`) VALUES (127, "percent2", "满券", 433, 4, "2020-06-03", 1590659565, 0.00, "");

INSERT INTO &#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的用户签到功能的实现示例: 1. 创建一个名为 `SignController` 的控制器,然后添加一个名为 `doSign` 的方法用于处理用户签到请求。 ```php class SignController extends Controller { public function doSign() { $uid = session('uid'); // 获取当前用户的ID $signModel = M('UserSign'); // 实例化用户签到模型 $lastSign = $signModel->where('uid='.$uid)->order('sign_time desc')->find(); // 获取用户最后一次签到记录 $today = date('Y-m-d'); // 获取当前日期 if(empty($lastSign) || $lastSign['sign_time'] < $today) { // 如果用户今天还没有签到 $data['uid'] = $uid; $data['sign_time'] = $today; $signModel->add($data); // 添加签到记录 $this->success('签到成功!'); } else { // 如果用户今天已经签到过了 $this->error('今天已经签到过了!'); } } } ``` 2. 创建一个名为 `UserSignModel` 的模型,用于操作用户签到记录表。 ```php class UserSignModel extends Model { protected $tableName = 'user_sign'; } ``` 3. 创建一个名为 `user_sign` 的数据表,用于存储用户签到记录。 ```sql CREATE TABLE `user_sign` ( `id` int(11) NOT NULL AUTO_INCREMENT, `uid` int(11) NOT NULL, `sign_time` date NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8; ``` 4. 在用户登录成功后,将用户ID存储到Session中。例如: ```php session('uid', $user['id']); ``` 5. 在前端页面上添加一个签到按钮,并在点击按钮时向服务器发送签到请求。例如: ```html <button id="sign-btn">签到</button> <script> $('#sign-btn').on('click', function() { $.ajax({ url: '/sign/doSign', type: 'POST', success: function(res) { if(res.code == 0) { alert(res.msg); } else { alert(res.msg); } } }); }); </script> ``` 以上就是一个简单的用户签到功能的实现示例,你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值