沉浸式阅读
Beta
转载

PHP+MYSQL+AJAX实现每日签到功能

     订阅 PHP     2022-07-03     网络转载    200    0    1    1    2022-07-03
学习要点:用代码测试

一、web前端及ajax部分文件

index.html

<html> 
<head> 
<meta http-equiv=Content-Type content="text/html;charset=utf-8"> 
<title>PHP+AJAX+MYSQL实现每日签到</title> 
<script type="text/javascript" src="js/jquery.min.js"></script>
 <script type="text/javascript">
   //page load get num 
   $(window).ready(function(){
     doGetDays();
   }); 
 
//get sign days 
 
 function doGetDays(){
   $.get("/sign.php?do=getDay",{},function(data){
     $("#days").html(data);
   });
 } 
 
//do sign 
 
 function doSign(){
   $.get("/sign.php?do=sign",{},function(data){ 
    if(data==1){
       alert("sign success!");
       window.location.href='/';
     }else if(data==2){
       alert("already sign today! next tomorrow!");
     }
 });
 }
 
</script>
</head> 
<body>
 <a style="cursor:pointer;" onclick="doSign();">签到<span>连续签到<span id="days"></span>天</span></a>
 </body> 
</html>


二、PHP后端处理部分 

sign.php文件

<?php
if ($_GET['do']=='getDay'){
  $db=new mysqli('localhost','root','123456','sign');
  $uid=2; $getDay="SELECT `signdays` FROM `user` WHERE `id`= {$uid}"; $day=$db -> query($getDay); $days =$day -> fetch_array(MYSQLI_ASSOC); echo $days['signdays'];
 }
if ($_GET['do']=='sign'){
   $db=new mysqli('localhost','root','123456','sign');
   $uid=2;
  $time=time();
  //check sign today
  $todayBegin=strtotime(date('Y-m-d')." 00:00:00");
  $todayEnd= strtotime(date('Y-m-d')." 23:59:59");
  $checkSignSql="SELECT * FROM `sign` WHERE `uid` = {$uid} AND `dateline` < {$todayEnd} AND `dateline` > {$todayBegin} ";
  $checkSignToday= $db -> query($checkSignSql);
  $checkSign = $checkSignToday -> fetch_array(MYSQLI_ASSOC);
   if (empty($checkSign)){
    $sql="SELECT * FROM `sign` WHERE `uid` = {$uid} ";
    $return = $db -> query($sql) -> fetch_array(MYSQL_ASSOC);
    //check sign table exist uid record
    if (empty($return)){//no
       $insertSql="INSERT INTO `sign` (`uid`,`dateline`) VALUES ('{$uid}','{$time}') ";
       $insert = $db -> query($insertSql);
       $updateSignSql="UPDATE `user` SET `signdays` =1 WHERE `id` = {$uid} ";
       $db -> query($updateSignSql); echo 1;
     }else{
      // check is continuous ? reset with login set signdays as 0 !!!!!
      $yesterdayBegin= strtotime(date("Y-m-d",strtotime("-1 day"))." 00:00:00");
      $yesterdayEnd= strtotime(date("Y-m-d",strtotime("-1 day"))." 23:59:59");
      $checkContinuSql="SELECT * FROM `sign` WHERE `uid` = {$uid} AND `dateline` < {$yesterdayEnd} AND `dateline` > {$yesterdayBegin}"; $checkContinuYesterday = $db ->query($checkContinuSql) -> fetch_array(MYSQL_ASSOC);
      if (!empty($checkContinuYesterday)){
        $replaceSql="REPLACE INTO `sign` (`uid`,`dateline`) VALUES ('{$uid}','{$time}') ";
        $replace=$db -> query($replaceSql);
        $updateSignSql="UPDATE `user` SET `signdays` = `signdays` + 1 WHERE `id` = {$uid} ";
        $db -> query($updateSignSql); echo 1;
      }else{
    }
  }
}else{
  echo 2;// allready sign.
}
?>


三、Mysql数据库部分

MYSQL

CREATE TABLE IF NOT EXISTS `sign` (
 `uid` int(11) NOT NULL,
 `dateline` varchar(10) COLLATE utf8_bin NOT NULL, PRIMARY KEY (`uid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
 
INSERT INTO `sign` (`uid`, `dateline`) VALUES (1, '1389072071'), (2, '1389072735'); 
 
CREATE TABLE IF NOT EXISTS `user` (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'USERID',
 `username` varchar(35) COLLATE utf8_bin NOT NULL COMMENT 'username',
 `signdays` int(11) NOT NULL COMMENT '签到天数', PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin AUTO_INCREMENT=3 ;
 
INSERT INTO `user` (`id`, `username`, `signdays`) VALUES (1, 'ggbound', 4), (2, 'other', 1);



本文标题: PHP+MYSQL+AJAX实现每日签到功能

本文链接: https://www.mbkfw.com/course/1086.html (转载时请注明来源链接)

本文说明: 本文来源于网络转载,有问题请发送至: 邮箱/kf@dtmuban.com 进行修改或删除

特别鸣谢: 如果您觉得本文对您有帮助,请给我们一个小小的赞,收藏本文更利于反复学习哦!

 
本文标签: #签到 #连签
destoon程序前端开发标签生成器

下班PC阅读不方便?

手机也可以随时学习开发

微信关注公众号“商企云服”
"模板开发网前端开发教学"
每日干货技术分享
 
0

圈友点评

文明上网理性发言,请遵守网络评论服务协议

小编推荐



色彩
×

《客户实名在线注册登记》售后一直都在!

关注

微信
关注

微信扫一扫
不同的环境体验

幸运大转盘,好礼等您拿

模板开发网公众号

模板开发网微信小程序

代授权

程序
授权

黑小二

联系
客服

很高兴为您服务
尊敬的用户,欢迎您咨询,我们为新用户准备了优惠好礼。咨询客服

联系客服:

在线QQ: 290948585

客服电话: 18605917465

E_mail邮箱: kf@dtmuban.com

微信公众号: 商企云服

微信小程序: 模板开发

QQ客服 微信客服DT授权代办 在线交谈 智能小云

工作时间:

周一至周五: 09:00 - 18:00

APP下载

安卓
APK

模板开发网安卓版APP

反馈

我要
反馈