php微信公众号开发之翻页查询


Posted in PHP onOctober 20, 2018

本文为大家分享了php微信公众号开发之翻页查询的具体代码,供大家参考,具体内容如下

注意:公众号列表最多只能列出8列,超出会报错

  • 分页原理
  • limit 开始位置 , 条数
  • (当前页数 - 1) x 每页条数 , 每页条数
  • limit ($Page - 1) * $PageSize , $PageSize
  • 0 为开始位置
  • mysql_num_rows 条数
  • require() 与 require_once() 开始加载,错误停止
  • include() 与 include_once() 使用加载,错误跳过
  • ceil 进一 向上取整

原理:

  • 总共10条,每页9条
  • n条
  • sum 总共几页 ceil ( n / 9 )
  • 开始条数 : (当前页数 - 1 ) x 每页条数
  • (key - 1)* 9

php微信公众号开发之翻页查询

注释:+1 是为了说明有多少页

>10 10

php微信公众号开发之翻页查询

php微信公众号开发之翻页查询

核心代码如下:

$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
        $fromUsername = $postObj->FromUserName;
        $toUsername = $postObj->ToUserName;
        $type = $postObj->MsgType;
        $customevent = $postObj->Event;
        $latitude = $postObj->Location_X;
        $longitude = $postObj->Location_Y;
        $keyword = trim($postObj->Content);
        $time = time();
        $textTpl = "<xml>
              <ToUserName><![CDATA[%s]]></ToUserName>
              <FromUserName><![CDATA[%s]]></FromUserName>
              <CreateTime>%s</CreateTime>
              <MsgType><![CDATA[%s]]></MsgType>
              <Content>%s</Content>
              <FuncFlag>0</FuncFlag>
              </xml>";       
        switch ($type)
        {  
        case "event";
        if ($customevent=="subscribe")
          {$contentStr = "感谢你的关注\n栏目正在搭建,敬请期待\n回复1看视频教程";}
        break;
        case "image";
          $contentStr = "你的图片很棒!";
          break;
        case "location";
          $contentStr = "你的纬度是{$latitude},经度是{$longitude},我已经锁定!";
          break;
        case "link" ;
          $contentStr = "你的链接有病毒吧!";
          break;
        case "text";
           include("coon.php");
           $num = "SELECT * FROM `kecheng` ";
           $que=mysql_query($num);
           $no=mysql_num_rows($que);//获得条数
           $sumpage=ceil($no/7);
           $page=(intval($keyword)-1)*7;
           $total=$no-$page+1;
           if($total>8)
           {$total=8;} 
           $sql = "SELECT * FROM `kecheng` ORDER BY `id` DESC LIMIT {$page},7";
           $query=mysql_query($sql);        
           $newsTpl = "<xml>
            <ToUserName><![CDATA[%s]]></ToUserName>
            <FromUserName><![CDATA[%s]]></FromUserName>
            <CreateTime>%s</CreateTime>
            <MsgType><![CDATA[news]]></MsgType>
            <ArticleCount>$total</ArticleCount>
            <Articles>
            <item>
            <Title><![CDATA[总共{$sumpage}页,输入页数翻页]]></Title>
            <Description><![CDATA[]]></Description>
            <PicUrl>http://autoguitar.duapp.com/1.jpg</PicUrl>
            <Url><![CDATA[]]></Url>
            </item>";
              while($rs=mysql_fetch_array($query)){    
              $newsTpl.="<item>
                   <Title>$rs[content]</Title> 
                   <Description><![CDATA[]]></Description>
                   <PicUrl>http://dq095.applinzi.com/2.jpg</PicUrl>
                   <Url><![CDATA[]]></Url>
                   </item>";
                   }
              $newsTpl.="</Articles>
                   <FuncFlag>0</FuncFlag>
                  </xml>";
           $myresultStr = sprintf($newsTpl, $fromUsername, $toUsername, $time);
           echo $myresultStr;
           break;         
        default;
          $contentStr ="此项功能尚未开发";  
        }
        $msgType="text";
        $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
        echo $resultStr;

coon.php连接数据库代码如下:

<?php

    //用 户 名 : $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函数操作进行数据库操作
    */

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;
        $type = $postObj->MsgType;
        $customevent = $postObj->Event;
        $latitude = $postObj->Location_X;
        $longitude = $postObj->Location_Y;
        $keyword = trim($postObj->Content);
        $time = time();
        $textTpl = "<xml>
              <ToUserName><![CDATA[%s]]></ToUserName>
              <FromUserName><![CDATA[%s]]></FromUserName>
              <CreateTime>%s</CreateTime>
              <MsgType><![CDATA[%s]]></MsgType>
              <Content>%s</Content>
              <FuncFlag>0</FuncFlag>
              </xml>";       
        switch ($type)
        {  
        case "event";
        if ($customevent=="subscribe")
          {$contentStr = "感谢你的关注\n栏目正在搭建,敬请期待\n回复1看视频教程";}
        break;
        case "image";
          $contentStr = "你的图片很棒!";
          break;
        case "location";
          $contentStr = "你的纬度是{$latitude},经度是{$longitude},我已经锁定!";
          break;
        case "link" ;
          $contentStr = "你的链接有病毒吧!";
          break;
        case "text";
           include("coon.php");
           $num = "SELECT * FROM `kecheng` ";
           $que=mysql_query($num);
           $no=mysql_num_rows($que);//获得条数
           $sumpage=ceil($no/7);
           $page=(intval($keyword)-1)*7;
           $total=$no-$page+1;
           if($total>8)
           {$total=8;} 
           $sql = "SELECT * FROM `kecheng` ORDER BY `id` DESC LIMIT {$page},7";
           $query=mysql_query($sql);        
           $newsTpl = "<xml>
            <ToUserName><![CDATA[%s]]></ToUserName>
            <FromUserName><![CDATA[%s]]></FromUserName>
            <CreateTime>%s</CreateTime>
            <MsgType><![CDATA[news]]></MsgType>
            <ArticleCount>$total</ArticleCount>
            <Articles>
            <item>
            <Title><![CDATA[总共{$sumpage}页,输入页数翻页]]></Title>
            <Description><![CDATA[]]></Description>
            <PicUrl>http://autoguitar.duapp.com/1.jpg</PicUrl>
            <Url><![CDATA[]]></Url>
            </item>";
              while($rs=mysql_fetch_array($query)){    
              $newsTpl.="<item>
                   <Title>$rs[content]</Title> 
                   <Description><![CDATA[]]></Description>
                   <PicUrl>http://dq095.applinzi.com/2.jpg</PicUrl>
                   <Url><![CDATA[]]></Url>
                   </item>";
                   }
              $newsTpl.="</Articles>
                   <FuncFlag>0</FuncFlag>
                  </xml>";
           $myresultStr = sprintf($newsTpl, $fromUsername, $toUsername, $time);
           echo $myresultStr;
           break;         
        default;
          $contentStr ="此项功能尚未开发";  
        }
        $msgType="text";
        $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
        echo $resultStr;

      }
  }

  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制作新闻系统的思路
Oct 09 PHP
网页游戏开发入门教程三(简单程序应用)
Nov 02 PHP
深入解析fsockopen与pfsockopen的区别
Jul 05 PHP
PHP连接MySQL查询结果中文显示乱码解决方法
Oct 25 PHP
php生成EAN_13标准条形码实例
Nov 13 PHP
linux下安装php的memcached客户端
Aug 03 PHP
基于递归实现的php树形菜单代码
Nov 19 PHP
PHP页面输出搜索后跳转下一页的处理方法
Sep 30 PHP
thinkPHP订单数字提醒功能的实现方法
Dec 01 PHP
php实时倒计时功能实现方法详解
Feb 27 PHP
php插件Xajax使用方法详解
Aug 31 PHP
laravel 实现根据字段不同值做不同查询
Oct 23 PHP
php微信公众号开发之校园图书馆
Oct 20 #PHP
php微信公众号开发之二级菜单
Oct 20 #PHP
php微信公众号开发之音乐信息
Oct 20 #PHP
php微信公众号开发之欢迎老朋友
Oct 20 #PHP
php微信公众号开发之秒杀
Oct 20 #PHP
php微信公众号开发之关键词回复
Oct 20 #PHP
php微信公众号开发之图片回复
Oct 20 #PHP
You might like
BBS(php &amp; mysql)完整版(六)
2006/10/09 PHP
深入PHP异步执行的详解
2013/06/03 PHP
php中利用explode函数分割字符串到数组
2014/02/08 PHP
thinkphp使用phpmailer发送邮件的方法
2014/11/24 PHP
PHP易混淆知识整理笔记
2015/09/24 PHP
基于jquery实现后台左侧菜单点击上下滑动显示
2013/04/11 Javascript
Javascript排序算法之计数排序的实例
2014/04/05 Javascript
JSON.parse()和JSON.stringify()使用介绍
2014/06/20 Javascript
JavaScript中的普通函数与构造函数比较
2015/04/07 Javascript
node.js回调函数之阻塞调用与非阻塞调用
2015/11/13 Javascript
JavaScript数组方法总结分析
2016/05/06 Javascript
漫谈JS引擎的运行机制 你应该知道什么
2016/06/15 Javascript
bootstrap css样式之表单
2017/01/19 Javascript
js操作浏览器的参数方法
2017/01/21 Javascript
一步一步的了解webpack4的splitChunk插件(小结)
2018/09/17 Javascript
jQuery事件模型默认行为执行顺序及trigger()与 triggerHandler()比较实例分析
2020/04/30 jQuery
Python初学时购物车程序练习实例(推荐)
2017/08/08 Python
Python实现字符串格式化输出的方法详解
2017/09/20 Python
对python:循环定义多个变量的实例详解
2019/01/20 Python
正确理解Python中if __name__ == '__main__'
2019/01/24 Python
Python读取stdin方法实例
2019/05/24 Python
Python3和pyqt5实现控件数据动态显示方式
2019/12/13 Python
python多进程重复加载的解决方式
2019/12/13 Python
python 写函数在一定条件下需要调用自身时的写法说明
2020/06/01 Python
Python中flatten( ),matrix.A用法说明
2020/07/05 Python
使用numpngw和matplotlib生成png动画的示例代码
2021/01/24 Python
python实现b站直播自动发送弹幕功能
2021/02/20 Python
CSS3中文字镂空、透明值、阴影效果设置示例小结
2016/03/07 HTML / CSS
Java中的基本数据类型所占存储空间大小固定的吗
2012/02/15 面试题
大学本科毕业生求职信范文
2013/12/18 职场文书
2014年五一促销活动方案
2014/03/09 职场文书
彩色的翅膀教学反思
2014/04/25 职场文书
分居协议书范本
2014/11/03 职场文书
机关工会工作总结2015
2015/05/26 职场文书
TypeScript中条件类型精读与实践记录
2021/10/05 Javascript
《吸血鬼:避世 血猎》官宣4.27发售 系列首款大逃杀
2022/04/03 其他游戏