php微信公众号开发之秒杀


Posted in PHP onOctober 20, 2018

本文实例为大家分享了php微信公众号秒杀功能的具体代码,供大家参考,具体内容如下

php微信公众号开发之秒杀

数据库小知识点:

strtotime:将字符串转换成时间
time():时间函数,调用系统当前时间 

php微信公众号开发之秒杀php微信公众号开发之秒杀
php微信公众号开发之秒杀

核心代码:

$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
 $fromUsername = $postObj->FromUserName;
 $toUsername = $postObj->ToUserName;
 $keyword = trim($postObj->Content);
 $time = time();
 $textTpl = "<xml>
    <ToUserName><![CDATA[%s]]></ToUserName>
    <FromUserName><![CDATA[%s]]></FromUserName>
    <CreateTime>%s</CreateTime>
    <MsgType><![CDATA[%s]]></MsgType>
    <Content><![CDATA[%s]]></Content>
    <FuncFlag>0</FuncFlag>
    </xml>"; 

 if($keyword=="秒杀")
 {
  //用 户 名 : $user
  //密码 : $pwd
  //主库域名 : $host
  //从库域名 : SAE_MYSQL_HOST_S
  //端口 : $port
  //数据库名 : $dbname

  $dbname = "app_dq095";
  $host = "w.rdc.sae.sina.com.cn";
  $port = "3306";
  $user = "4k514n103z";
  $pwd = "密码";

  /*接着调用mysql_connect()连接服务器*/
  // 连主库
  $db = mysql_connect($host,$user,$pwd);

  if(!$db){
   die("Connect Server Failed: " . mysql_error($db));
  }

  /*连接成功后立即调用mysql_select_db()选中需要连接的数据库*/
  if (!mysql_select_db($dbname)) {
   die("Select Database Failed: " . mysql_error($db));
  }
  mysql_query("set names utf-8",$db); 

  /*至此连接已完全建立,就可对当前数据库进行相应的操作了*/
  /*!!!注意,无法再通过本次连接调用mysql_select_db来切换到其它数据库了!!!*/
  /* 需要再连接其它数据库,请再使用mysql_connect+mysql_select_db启动另一个连接*/

  /**
  * 接下来就可以使用其它标准php mysql函数操作进行数据库操作
  */
  $msgType = "text";
  $shijian=strtotime("2018-08-23 23:00:00")-time();
  if($shijian>0)
  {
   $contentStr = "对不起,秒杀还没开始,2018年8月23日23点开始";
  }else{
   $sql="SELECT * FROM `welcome`WHERE `user`= '" . iconv("UTF-8","GBK",$fromUsername) . "'";
   $query=mysql_query($sql);
   $rs=mysql_fetch_array($query);
   $b= $rs['user'];
   $c=iconv("GBK","UTF-8",$b);

   if ($c==$fromUsername)
   {
    $contentStr = "你已经秒杀过了!";
   }else{
    $sql="SELECT `num` FROM `shuzi` WHERE 1";
    $query=mysql_query($sql);
    $rs=mysql_fetch_array($query);
    $b= $rs['num'];
    if ($b>0)
    {
     $contentStr = "恭喜你秒杀成功,凭此条微信到本店10元换取礼品";
     $b--;
     $sql="UPDATE `shuzi` SET `num`={$b} WHERE 1";
     mysql_query($sql); 

    }else{
     $contentStr = "很遗憾,你没有秒杀成功,下次再来吧!";
    }
    $sqluser="INSERT INTO `welcome`(`id`,`user`) VALUES (NULL,'{$fromUsername}')";
    mysql_query($sqluser);
   }

  }

  $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);     
  echo $resultStr;
  mysql_close($db);

 }else{
  echo "Input something...";
 }

数据库代码如下:

-- phpMyAdmin SQL Dump
-- version 3.3.8.1
-- http://www.phpmyadmin.net
--
-- 主机: w.rdc.sae.sina.com.cn:3307
-- 生成日期: 2018 年 08 月 23 日 22:29
-- 服务器版本: 5.6.23
-- PHP 版本: 5.3.3

SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
--
-- 数据库: `app_dq095`
--
-- --------------------------------------------------------
--
-- 表的结构 `shuzi`
--

CREATE TABLE IF NOT EXISTS `shuzi` (
 `num` int(11) NOT NULL DEFAULT '0'
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

--
-- 转存表中的数据 `shuzi`
--

INSERT INTO `shuzi` (`num`) VALUES
(0);

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

--
-- 表的结构 `welcome`
--

CREATE TABLE IF NOT EXISTS `welcome` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `user` varchar(255) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=6 ;

--
-- 转存表中的数据 `welcome`
--

INSERT INTO `welcome` (`id`, `user`) VALUES
(5, 'ooD-ow-C8ZigAihscJN54pAWpu2g');

index.php代码如下:

<?php
/**
 * wechat php test
 */

//define your token
define("TOKEN", "weixin");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->responseMsg();

class wechatCallbackapiTest
{
 public function valid()
 {
  $echoStr = $_GET["echostr"];

  //valid signature , option
  if($this->checkSignature()){
   echo $echoStr;
   exit;
  }
 }

 public function responseMsg()
 {
  //get post data, May be due to the different environments
  $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

  //extract post data
  if (!empty($postStr)){


    $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
    $fromUsername = $postObj->FromUserName;
    $toUsername = $postObj->ToUserName;
    $keyword = trim($postObj->Content);
    $time = time();
    $textTpl = "<xml>
       <ToUserName><![CDATA[%s]]></ToUserName>
       <FromUserName><![CDATA[%s]]></FromUserName>
       <CreateTime>%s</CreateTime>
       <MsgType><![CDATA[%s]]></MsgType>
       <Content><![CDATA[%s]]></Content>
       <FuncFlag>0</FuncFlag>
       </xml>"; 

    if($keyword=="秒杀")
    {
     //用 户 名 : $user
     //密码 : $pwd
     //主库域名 : $host
     //从库域名 : SAE_MYSQL_HOST_S
     //端口 : $port
     //数据库名 : $dbname

     $dbname = "app_dq095";
     $host = "w.rdc.sae.sina.com.cn";
     $port = "3306";
     $user = "4k514n103z";
     $pwd = "2402314li2j1i5im1xy2xizj5y332w2x41k2z203";

     /*接着调用mysql_connect()连接服务器*/
     // 连主库
     $db = mysql_connect($host,$user,$pwd);

     if(!$db){
      die("Connect Server Failed: " . mysql_error($db));
     }

     /*连接成功后立即调用mysql_select_db()选中需要连接的数据库*/
     if (!mysql_select_db($dbname)) {
      die("Select Database Failed: " . mysql_error($db));
     }
      mysql_query("set names utf-8",$db); 

     /*至此连接已完全建立,就可对当前数据库进行相应的操作了*/
     /*!!!注意,无法再通过本次连接调用mysql_select_db来切换到其它数据库了!!!*/
     /* 需要再连接其它数据库,请再使用mysql_connect+mysql_select_db启动另一个连接*/

     /**
      * 接下来就可以使用其它标准php mysql函数操作进行数据库操作
      */
     $msgType = "text";
      $shijian=strtotime("2018-08-23 23:00:00")-time();
      if($shijian>0)
      {
       $contentStr = "对不起,秒杀还没开始,2018年8月23日23点开始";
      }else{
       $sql="SELECT * FROM `welcome`WHERE `user`= '" . iconv("UTF-8","GBK",$fromUsername) . "'";
       $query=mysql_query($sql);
       $rs=mysql_fetch_array($query);
       $b= $rs['user'];
       $c=iconv("GBK","UTF-8",$b);

       if ($c==$fromUsername)
       {
        $contentStr = "你已经秒杀过了!";
       }else{
        $sql="SELECT `num` FROM `shuzi` WHERE 1";
        $query=mysql_query($sql);
        $rs=mysql_fetch_array($query);
        $b= $rs['num'];
        if ($b>0)
        {
        $contentStr = "恭喜你秒杀成功,凭此条微信到本店10元换取礼品";
        $b--;
        $sql="UPDATE `shuzi` SET `num`={$b} WHERE 1";
        mysql_query($sql); 

        }else{
        $contentStr = "很遗憾,你没有秒杀成功,下次再来吧!";
        }
        $sqluser="INSERT INTO `welcome`(`id`,`user`) VALUES (NULL,'{$fromUsername}')";
        mysql_query($sqluser);
       }

      }

      $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);     
      echo $resultStr;
      mysql_close($db);

    }else{
     echo "Input something...";
    }


  }else {
   echo "";
   exit;
  }
 }

 private function checkSignature()
 {
  $signature = $_GET["signature"];
  $timestamp = $_GET["timestamp"];
  $nonce = $_GET["nonce"]; 

  $token = TOKEN;
  $tmpArr = array($token, $timestamp, $nonce);
  sort($tmpArr);
  $tmpStr = implode( $tmpArr );
  $tmpStr = sha1( $tmpStr );

  if( $tmpStr == $signature ){
   return true;
  }else{
   return false;
  }
 }
}

?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php执行sql语句的写法
Mar 10 PHP
解决ajax+php中文乱码的方法详解
Jun 09 PHP
ajax返回值中有回车换行、空格的解决方法分享
Oct 24 PHP
php实现的DateDiff和DateAdd时间函数代码分享
Aug 16 PHP
php中get_object_vars()方法用法实例
Feb 08 PHP
PHP表单提交后引号前自动加反斜杠的原因及三种办法关闭php魔术引号
Sep 30 PHP
在WordPress中使用wp-cron插件来设置定时任务
Dec 10 PHP
Zend Framework实现Zend_View集成Smarty模板系统的方法
Mar 05 PHP
PHP读书笔记_运算符详解
Jul 01 PHP
PHP读MYSQL中文乱码的快速解决方法
Oct 01 PHP
php操作路径的经典方法(必看篇)
Oct 04 PHP
PHP时间函数使用详解
Mar 21 PHP
php微信公众号开发之关键词回复
Oct 20 #PHP
php微信公众号开发之图片回复
Oct 20 #PHP
php5.x禁用eval的操作方法
Oct 19 #PHP
django中的ajax组件教程详解
Oct 18 #PHP
Laravel关联模型中过滤结果为空的结果集(has和with区别)
Oct 18 #PHP
PHP使用glob方法遍历文件夹下所有文件的实例
Oct 17 #PHP
php 读取文件夹下所有图片、文件的实例
Oct 17 #PHP
You might like
PHP XML备份Mysql数据库
2009/05/27 PHP
用php获取本周,上周,本月,上月,本季度日期的代码
2009/08/05 PHP
php异常:Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE  eval()'d code error
2011/05/19 PHP
PHP函数学习之PHP函数点评
2012/07/05 PHP
php实现水印文字和缩略图的方法示例
2016/12/29 PHP
PHP并发查询MySQL的实例代码
2017/08/09 PHP
php使用redis的几种常见操作方式和用法示例
2020/02/20 PHP
PHP pthreads v3下的Volatile简介与使用方法示例
2020/02/21 PHP
JavaScript 给汉字排序实例代码
2008/06/28 Javascript
JavaScript实现页面滚动图片加载(仿lazyload效果)
2011/07/22 Javascript
基于jQuery判断两个元素是否有重叠部分的代码
2012/07/25 Javascript
Jquery仿IGoogle实现可拖动窗口示例代码
2014/08/22 Javascript
js实现发送验证码后的倒计时功能
2015/05/28 Javascript
JQUERY表单暂存功能插件分享
2016/02/23 Javascript
微信小程序(三):网络请求
2017/01/13 Javascript
js实现固定宽高滑动轮播图效果
2017/01/13 Javascript
JS点击图片弹出文件选择框并覆盖原图功能的实现代码
2017/08/25 Javascript
Vue中对比scoped css和css module的区别
2018/05/17 Javascript
vue中的适配px2rem示例代码
2018/11/19 Javascript
[37:02]OG vs INfamous 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Windows中安装使用Virtualenv来创建独立Python环境
2016/05/31 Python
Python中矩阵创建和矩阵运算方法
2018/08/04 Python
对Python+opencv将图片生成视频的实例详解
2019/01/08 Python
基于Python实现拆分和合并GIF动态图
2019/10/22 Python
Python input函数使用实例解析
2019/11/22 Python
python接口自动化之ConfigParser配置文件的使用详解
2020/08/03 Python
python smtplib发送多个email联系人的实现
2020/10/09 Python
HTML5 canvas基本绘图之绘制线条
2016/06/27 HTML / CSS
香港钟表珠宝首饰商城:OneMallTime网摩间
2016/10/14 全球购物
社区志愿者活动总结
2014/06/26 职场文书
交通运输局四风问题对照检查材料思想汇报
2014/10/09 职场文书
旷课检讨书范文
2014/10/30 职场文书
2014年学校食堂工作总结
2014/11/25 职场文书
师德师风心得体会(2016精选篇)
2016/01/12 职场文书
python3实现常见的排序算法(示例代码)
2021/07/04 Python
Java反应式框架Reactor中的Mono和Flux
2021/07/25 Java/Android