PHP连续签到功能实现方法详解

时间:2022-07-27
本文章向大家介绍PHP连续签到功能实现方法详解,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

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

require "./global.php";
  $act = isset($_GET['act']) ? $_GET['act'] : "error";
  // d($act);
  switch($act){
    case "qiandao":
      $uid = intval($_POST['uid']);
      $res = $db -  get('qian_dao','*',array('uid'= $uid));
      // last_query();
      $time = time();
      //判断今天是否签到
      $todayBegin=strtotime(date('Y-m-d')." 00:00:00"); 
      $todayEnd= strtotime(date('Y-m-d')." 23:59:59"); 
      $isexit = $db -  get('qian_dao','id',array('AND'= array('uid'= $uid,'qian_dao_time[ =]'= $todayBegin,'qian_dao_time[<=]'= $todayEnd)));
      // last_query();
      if($isexit){
        // echo "今天已签到!";
        Log::writeLog(print_r(array('state'= 'stop','msg'= '今天已签到!'),true));
        echo json_encode(array('state'= 'stop','msg'= '今天已签到!'));
        exit;
      }
      if($res){
        //存在签到
        if((time() - $res['qian_dao_time']   24*60*60)){ // 判断时间是否大于24小时
          // 让字段归0
          $addInfo = $db -  update('qian_dao',array('qian_dao_num'= 1,'qian_dao_time'= $time),array('uid'= $uid));
        }else{
          // 更新签到的天数
          $addInfo = $db -  update('qian_dao',array('qian_dao_num[+]'= 1,'qian_dao_time'= $time),array('uid'= $uid));
        }
      }else{
        // echo '您还没有签到过';
        //没有签到过
        $db -  insert('qian_dao',array('uid'= $uid,'qian_dao_num'= 1,'qian_dao_time'= $time));
        // echo $db - last_query();
      }
      // 插入签到记录
      $db -  insert('sign',array(
        'uid'= $uid,
        'dateline'= $time,
      ));
      // 获取连续签到的天数
      $info = $db -  get('qian_dao','qian_dao_num',array('uid'= $uid));
      echo json_encode(array('state'= 'success','msg'= "您是第".$info."天签到"));
      break;
    default :
      echo json_encode(array("ret"= 0,"msg"= "操作不存在!"));
      break;
  }

sql:

CREATE TABLE IF NOT EXISTS `qian_dao` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `uid` int(1) NOT NULL COMMENT '用户id',
 `qian_dao_num` int(11) NOT NULL COMMENT '签到次数',
 `qian_dao_time` int(11) NOT NULL COMMENT '签到时间',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
CREATE TABLE IF NOT EXISTS `sign` (
 `uid` int(11) NOT NULL,
 `dateline` varchar(10) COLLATE utf8_bin NOT NULL,
 KEY `uid` (`uid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

html:

<?php
include './global.php';
$uid = 1;
$todayBegin=strtotime(date('Y-m-d')." 00:00:00"); 
$todayEnd= strtotime(date('Y-m-d')." 23:59:59"); 
$isexit = $db -  get('qian_dao','id',array('AND'= array('uid'= $uid,'qian_dao_time[ =]'= $todayBegin,'qian_dao_time[<=]'= $todayEnd)));
$flag = '';
if($isexit){
$flag = 'current';
}
? 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" 
<html xmlns="http://www.w3.org/1999/xhtml" 
<head 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" / 
<title jquery制作每天或每日打卡签到特效</title 
<meta name="description" content="jquery制作论坛或社交网站的每日或每天打卡签到特效,点击打卡标签显示打卡签到效果。jquery下载" / 
</head 
<body 
<style type="text/css" 
*{margin:0;padding:0;list-style-type:none;}
a,img{border:0;text-decoration:none;}
/*今日签到*/
.singer{border:1px solid #DCDBDB;padding:10px;height:45px;line-height:45px;width:290px;margin:20px auto;}
.ul{border:1px solid #DCDBDB;padding:0 10px 10px 10px;;width:290px;margin:20px auto;}
.li{border:1px solid #DCDBDB;padding-left:10px;height:25px;line-height:25px;width:280px;margin:10px 0 0 0;}
.singer_l_cont, .singer_r_img{float:left;}
.singer_l_cont{width:145px;background:url(images/sing_per.gif) no-repeat left 12px;text-indent:23px;font-size:12px;}
.singer_r_img{display:block;width:114px;height:52px;background:url(images/sing_week.gif) right 2px no-repeat;vertical-align:middle;float:right;*margin-bottom:-10px;}
.singer_r_img:hover{background-position:right -53px;text-decoration:none;}
.singer_r_img span{margin-left:14px;font-size:16px;font-family:'Hiragino Sans GB','Microsoft YaHei',sans-serif !important;font-weight:700;color:#165379;}
.singer_r_img.current{background:url(images/sing_sing.gif) no-repeat 0 2px;}
</style 
<div class="singer" 
<div class="singer_l_cont" 
<span 每天签到赢取PK币</span 
</div 
<div class="singer_r_r" 
<a class="singer_r_img <?php echo $flag;? " href="#" rel="external nofollow"      
<span id="sing_for_number" </span 
</a 
</div 
</div <!--singer end-- 
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js" </script 
<script type="text/javascript" 
/*签到模块日期捕捉:*/
function week(){
var objDate= new Date();
var week = objDate.getDay();
switch(week)
{
case 0:
week="周日";
break;
case 1:
week="周一";
break;
case 2:
week="周二";
break;
case 3:
week="周三";
break;
case 4:
week="周四";
break;
case 5:
week="周五";
break;
case 6:
week="周六";
break;
}
$("#sing_for_number").html( week );
}
$(document).ready(function(){
week();
var cache=new Array(); // 缓存变量,当数据被访问过之后放置在缓存中,加快访问速度
$(".singer_r_img").click(function(){
// 如果缓存中存在数据,那么直接从缓存中读取;如果不存在数据,那么就从数据库中读取,并把数据存入缓存
if (typeof(cache['stop'])=='undefined') {
$.ajax({
url:"action.php?act=qiandao",
type:"post",
dataType:'json',
data:{
uid:1,
},
async:false,
success:function(data){
// alert(data.msg);
switch(data.state){
case 'success':
alert(data.msg);
break
case 'stop':
cache['stop'] = data.msg;
alert(data.msg);
break;
}
$(".singer_r_img").addClass("current");
}
})
}else{
alert(cache['stop'])
}
})
})
</script 
</body 
</html 
<?php
// 获取签到记录
$sign = $db -  select('sign','*',array('uid'= $uid,'ORDER'= 'dateline DESC'));
? 
<ul class='ul' 
<?php
if(empty($sign)){
? 
<li class="li" 暂无签到信息</li 
<?php
}else{
foreach($sign as $k= $v){
? 
<li class="li" <span <?php echo ($k + 1);? </span &nbsp;<?php echo date('Y-m-d H:i:s',$v['dateline']);? </li 
<?php
}
}
? 
</ul 

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php+mysql数据库操作入门教程》、《php+mysqli数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。