thinkPHP实现签到功能的方法

发布时间 - 2026-01-11 00:10:24    点击率:

本文实例讲述了thinkPHP实现签到功能的方法。分享给大家供大家参考,具体如下:

数据表:

CREATE TABLE `members_sign` (
 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
 `uid` int(11) unsigned NOT NULL COMMENT '用户id',
 `days` tinyint(2) unsigned NOT NULL DEFAULT '0' COMMENT '连续签到的天数',
 `is_share` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否分享过',
 `is_sign` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '是否签到过',
 `stime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '签到的时间',
 `atime` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '添加时间',
 PRIMARY KEY (`id`),
 KEY `index_uid` (`uid`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=162 DEFAULT CHARSET=utf8 COMMENT='签到分享表';

Controller:

<?php
namespace Member\Controller;
use Member\Controller\MController;
class IndexController extends MController {
  /**
  * 用户中心
  * @param
  */
  public function index(){
    $pre = C('DB_PREFIX');
        // 日历列表
    $monthSign = $this->getMonthSign();
    $dayList = $this->showDays($monthSign);
    // 今天签到
    $data = $this->todayData();
    if($data['is_sign'] == 1){
      $this->assign('isSign',true);
    }
    $this->display();
  }
  /**
  * 执行当天签到
  * @return json 签到成功返回 {status:1,info:'已签到'}
  */
  public function sign(){
    $todayData = $this->todayData();
    if($todayData['is_sign'] == 1){
      $this->successMsg('已签到');
    }else{
      $data = $this->getInsertData($this->uid);
      // 无今天数据
      if($todayData == NULL){
        $data['uid'] = $this->uid;
        $data['atime'] = time();
        $id = M('members_sign')->add($data);
      }else{
        $save = M('members_sign')->where("id = {$todayData['id']}")->save($data);
      }
      if($id or $save){
        $score = $this->getTodayScores($data['days']);
        // 为该用户添加积分
        addScore($this->uid,$score);
        $this->successMsg('已签到',array('score' => $score,'days'=>$data['days']));
      }else{
        $this->errorMsg('签到失败,请刷新后重试!');
      }
    }
  }
  /**
  * 返回每次签到要插入的数据
  *
  * @param int $uid 用户id
  * @return array(
  *  'days'   =>  '天数',
  *  'is_sign'  =>  '是否签到,用1表示已经签到',
  *  'stime'   =>  '签到时间',
  * );
  */
  protected function getInsertData($uid){
    // 昨天的连续签到天数
    $start_time = strtotime(date('Y-m-d 0:0:0',time()-86400))-1;
    $end_time  = strtotime(date('Y-m-d 23:59:59',time()-86400))+1;
    $days = M('members_sign')->where("uid = $uid and atime > $start_time and atime < $end_time")->getField('days');
    if($days){
      $days++;
      if($days > 30){
        $days = 1;
      }
    }else{
      $days = 1;
    }
    return array(
      'days'    => $days,
      'is_sign'  => 1,
      'stime'   => time()
    );
  }
  /**
  * 用户当天签到的数据
  * @return array 签到信息 is_sign,stime 等
  */
  protected function todayData(){
    $time = time();
    $start_stime  = strtotime(date('Y-m-d 0:0:0',$time))-1;
    $end_stime = strtotime(date('Y-m-d 23:59:59',$time))+1;
    return M('members_sign')->field('atime',true)->where("uid = {$this->uid} and atime > $start_stime and atime < $end_stime")->find();
  }
  /**
  * 积分规则,返回连续签到的天数对应的积分
  *
  * @param int $days 当天应该得的分数
  * @return int 积分
  */
  protected function getTodayScores($days){
    if($days == 30){
      return 50;
    }else if($days > 19){
      return 8;
    }else if($days > 9){
      return 5;
    }else{
      return 3;
    }
  }
  /**
  * 显示签到列表
  *
  * @param array  $signDays 某月签到的日期 array(1,2,3,4,5,12,13)
  * @param int $year    可选,年份
  * @param int $month   可选,月份
  * @return string 日期列表<li>1</li>....
  */
  protected function showDays($signDays,$year,$month){
    $time = time();
    $year = $year ? $year : date('Y',$time);
    $month = $month ? $month : date('m',$time);
    $daysTotal = date('t', mktime(0, 0, 0, $month, 1, $year));
    $now = date('Y-m-d',$time);
    $str = '';
    for ($j = 1; $j <= $daysTotal; $j++) {
      $i++;
      $someDay = date('Y-m-d',strtotime("$year-$month-$j"));
      // 小于今天的日期样式
      if ($someDay <= $now){
        // 当天日期样式 tdc = todayColor
        if($someDay == $now){
          // 当天签到过的
          if(in_array($j,$signDays)){
            $str .= '<li class="current fw tdc">'.$j.'</li>';
          }else{
            $str .= '<li class="today fw tdc">'.$j.'</li>';
          }
        }else{
          // 签到过的日期样式 current bfc = beforeColor , fw = font-weight
          if(in_array($j,$signDays)){
            $str .= '<li class="current fw bfc">'.$j.'</li>';
          }else{
            $str .= '<li class="fw bfc">'.$j.'</li>';
          }
        }
      }else{
        $str .= '<li>'.$j.'</li>';
      }
    }
    return $str;
  }
  /**
  * 获取当月签到的天数,与 $this->showDays() 配合使用
  * @return 当月签到日期 array(1,2,3,4,5,12,13)
  */
  protected function getMonthSign(){
    $time  = time();
    $year  = date('Y',$time);
    $month = date('m',$time);
    $day  = date("t",strtotime("$year-$month"));
    $start_stime  = strtotime("$year-$month-1 0:0:0")-1;
    $end_stime = strtotime("$year-$month-$day 23:59:59")+1;
    $list = M('members_sign')->where("uid = {$this->uid} and stime > $start_stime and stime < $end_stime")->order('stime asc')->getField('stime',true);
    foreach ($list as $key => $value){
      $list[$key] = date('j',$value);
    }
    return $list;
  }
}

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》、《smarty模板入门基础教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。


# thinkPHP  # 签到功能  # tp5(thinkPHP5)框架数据库Db增删改查常见操作总结  # tp5(thinkPHP5)框架实现多数据库查询的方法  # thinkPHP5实现数据库添加内容的方法  # tp5(thinkPHP5)框架连接数据库的方法示例  # thinkPHP5框架数据库连贯操作之cache()用法分析  # thinkPHP5框架实现多数据库连接  # 跨数据连接查询操作示例  # Thinkphp5框架实现获取数据库数据到视图的方法  # ThinkPHP5.1框架数据库链接和增删改查操作示例  # PHP利用pdo_odbc实现连接数据库示例【基于ThinkPHP5.1搭建的项目】  # 基于ThinkPHP5框架使用QueryList爬取并存入mysql数据库操作示例  # ThinkPHP5.0框架实现切换数据库的方法分析  # TP5框架实现签到功能的方法分析  # 当天  # 到过  # 当月  # 可选  # 进阶  # 相关内容  # 感兴趣  # 给大家  # 添加时间  # 更多关于  # 所述  # 程序设计  # 重试  # 为该  # 操作技巧  # 昨天  # 讲述了  # Member  # namespace  # MController 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 利用vue写todolist单页应用  郑州企业网站制作公司,郑州招聘网站有哪些?  非常酷的网站设计制作软件,酷培ai教育官方网站?  如何快速搭建FTP站点实现文件共享?  Laravel如何使用Livewire构建动态组件?(入门代码)  文字头像制作网站推荐软件,醒图能自动配文字吗?  太平洋网站制作公司,网络用语太平洋是什么意思?  Laravel怎么在Controller之外的地方验证数据  Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧  青岛网站建设如何选择本地服务器?  佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】  Laravel如何使用.env文件管理环境变量?(最佳实践)  长沙企业网站制作哪家好,长沙水业集团官方网站?  Android自定义控件实现温度旋转按钮效果  企业网站制作这些问题要关注  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何在服务器上三步完成建站并提升流量?  HTML 中如何正确使用模板变量为元素的 name 属性赋值  如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel如何实现API资源集合?(Resource Collection教程)  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  微信小程序 input输入框控件详解及实例(多种示例)  Python文本处理实践_日志清洗解析【指导】  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  奇安信“盘古石”团队突破 iOS 26.1 提权  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  微信小程序 HTTPS报错整理常见问题及解决方案  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  微信小程序 canvas开发实例及注意事项  Laravel如何实现API版本控制_Laravel版本化API设计方案  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  网站制作大概多少钱一个,做一个平台网站大概多少钱?  如何用低价快速搭建高质量网站?  EditPlus中的正则表达式 实战(2)  详解阿里云nginx服务器多站点的配置  Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  android nfc常用标签读取总结  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  如何在不使用负向后查找的情况下匹配特定条件前的换行符  音乐网站服务器如何优化API响应速度?  Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】  手机软键盘弹出时影响布局的解决方法