微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

一、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){ <br>if(data==1){

 alert("sign success!");

 window.location.href='/';

  }else if(data==2){

 alert("already sign today! next tomorrow!");

  }

 });

 } 

</script> 

</head>

<body> 

<a 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','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`,'{$time}') "; 

$replace=$db -> query($replacesql); 

$updateSignsql="UPDATE `user` SET `signdays` = `signdays` + 1 WHERE `id` = {$uid} ";<br>

$db -> query($updateSignsql); echo 1; 

}else{

}

}

}else{ 

echo 2;// allready sign.  

?>

三、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),'other',1);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐