登录  /  注册
首页 > php教程 > php手册 > 正文

PHP+MYSQL+AJAX实现每日签到

php中文网
发布: 2016-06-06 19:59:02
原创
1262人浏览过

在现在的好多网站上都出现了每日签到以及签到送等互动功能,这边呢,作者就使用最原始的PHP配合MYSQL、AJAX来制作了一个简单的每日签到功能,至于送还有其他的小游戏就需要读者们自己去增加和拓展了。 下面先看下文件目录: database: 顾名思义就是存放数据

在现在的好多网站上都出现了每日签到以及签到送礼等互动功能,这边呢,作者就使用最原始的php配合mysql、ajax来制作了一个简单的每日签到功能,至于送礼还有其他的小游戏就需要读者们自己去增加和拓展了。

下面先看下文件目录:

PHP+MYSQL+AJAX实现每日签到

database:

顾名思义就是存放数据库SQL语句的文件,里面存放了已经设计好的简单的几张表。

js:

存放JS脚本库。

index.php

用的是.PHP为后缀的,其实下面看到后,读者可能会说,里面没PHP代码,直接弄成.HTML的后缀好了,其实大家可以自己去修改的,作者就不更改了。

index.php code:

	
		<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><a style="cursor:pointer;" onclick="doSign();">签到<span>连续签到<span id="days"></span>天</span></a>
	
登录后复制
sign.php 该文件就是具体处理签到的PHP代码了,具体的code如下:
<?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 -&gt; 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`  {$todayBegin} ";
		$checkSignToday= $db -&gt; query($checkSignSql);
		$checkSign = $checkSignToday -&gt; fetch_array(MYSQLI_ASSOC);
		if (empty($checkSign)){
			$sql="SELECT * FROM `sign` WHERE `uid` = {$uid} ";
			$return = $db -&gt; query($sql) -&gt; 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 -&gt; query($insertSql);
				$updateSignSql="UPDATE `user` SET `signdays` =1 WHERE `id` = {$uid} ";
				$db -&gt; 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`  {$yesterdayBegin}";
				$checkContinuYesterday = $db -&gt;query($checkContinuSql)-&gt;fetch_array(MYSQL_ASSOC);
				if (!empty($checkContinuYesterday)){
					$replaceSql="REPLACE INTO `sign` (`uid`,`dateline`) VALUES ('{$uid}','{$time}') ";
					$replace=$db -&gt; query($replaceSql);
					$updateSignSql="UPDATE `user` SET `signdays` = `signdays` + 1 WHERE `id` = {$uid} ";
					$db -&gt; query($updateSignSql);
					echo 1;
				}else{
登录后复制
登录后复制
}
			}
		}else{
			echo 2;// allready sign.
		}
	}
?&gt;
登录后复制
数据库:测试数据库结构及具体内容如下
-- phpMyAdmin SQL Dump
-- version 3.4.8
-- http://www.phpmyadmin.net
--
-- Host: localhost
-- Generation Time: Jan 07, 2014 at 01:32 PM
-- Server version: 5.5.28
-- PHP Version: 5.2.17p1

SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;

--
-- Database: `sign`
--

-- --------------------------------------------------------

--
-- Table structure for table `sign`
--

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;

--
-- Dumping data for table `sign`
--

INSERT INTO `sign` (`uid`, `dateline`) VALUES
(1, '1389072071'),
(2, '1389072735');

-- --------------------------------------------------------

--
-- Table structure for table `user`
--

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 ;

--
-- Dumping data for table `user`
--

INSERT INTO `user` (`id`, `username`, `signdays`) VALUES
(1, 'ggbound', 4),
(2, 'other', 1);

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
登录后复制
到此一个每日签到的功能就基本完成了!
智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号