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 相关文章推荐
Dedecms常用函数解析
Feb 01 PHP
PHP一些常用的正则表达式字符的一些转换
Jul 29 PHP
PHP下对数组进行排序的函数
Aug 08 PHP
数据库中排序的对比及使用条件详解
Feb 23 PHP
PHP时间格式控制符对照表分享
Jul 23 PHP
php smarty模板引擎的6个小技巧
Apr 24 PHP
使用配置类定义Codeigniter全局变量
Jun 12 PHP
WordPress开发中用于获取近期文章的PHP函数使用解析
Jan 05 PHP
php自动载入类用法实例分析
Jun 24 PHP
php实现当前页面点击下载文件的简单方法
Sep 22 PHP
Windows 下安装 swoole 图文教程(php)
Jun 05 PHP
php中yar框架实例用法讲解
Dec 27 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
星际争霸兵种名称对照表
2020/03/04 星际争霸
php xml-rpc远程调用
2008/12/19 PHP
php将mysql数据库整库导出生成sql文件的具体实现
2014/01/08 PHP
php实现文件下载代码分享
2014/08/19 PHP
简单实用的PHP防注入类实例
2014/12/05 PHP
Codeigniter控制器controller继承问题实例分析
2016/01/19 PHP
降低PHP Redis内存占用
2017/03/23 PHP
解决PHP使用CURL发送GET请求时传递参数的问题
2019/10/11 PHP
jquery 简短右键菜单 多浏览器兼容
2010/01/01 Javascript
动态加载图片路径 保持JavaScript控件的相对独立性
2010/09/03 Javascript
jQuery EasyUI API 中文文档 - EasyLoader 加载器
2011/09/29 Javascript
JavaScript中使用Substring删除字符串最后一个字符
2013/11/03 Javascript
JQuery控制radio选中和不选中方法总结
2015/04/15 Javascript
详解maxlength属性在textarea里奇怪的表现
2015/12/27 Javascript
Underscore源码分析
2015/12/30 Javascript
原生JavaScript制作计算器
2016/10/16 Javascript
Bootstrap基本组件学习笔记之进度条(15)
2016/12/08 Javascript
jQuery实现在新增加的元素上添加事件方法案例分析
2017/02/09 Javascript
Angular自定义组件实现数据双向数据绑定的实例
2017/12/11 Javascript
vue  自定义组件实现通讯录功能
2018/09/30 Javascript
redux处理异步action解决方案
2020/03/22 Javascript
Vue如何提升首屏加载速度实例解析
2020/06/25 Javascript
python实现TF-IDF算法解析
2018/01/02 Python
python获取命令行输入参数列表的实例代码
2018/06/23 Python
Python实现的json文件读取及中文乱码显示问题解决方法
2018/08/06 Python
Html5实现用户注册自动校验功能实例代码
2016/05/24 HTML / CSS
HTML里显示pdf、word、xls、ppt的方法示例
2020/04/14 HTML / CSS
美国棒球装备和用品商店:Baseball Savings
2018/06/09 全球购物
Yummie官方网站:塑身衣和衣柜必需品
2019/10/29 全球购物
请解释virtual关键字的含义
2015/06/17 面试题
传统软件工程与面向对象的软件工程有什么区别
2012/05/31 面试题
自荐书封面下载
2013/11/29 职场文书
学习十八大报告感言
2014/02/04 职场文书
学习教师法的心得体会
2014/09/03 职场文书
Pyqt5将多个类组合在一个界面显示的完整示例
2021/09/04 Python
苹果M1芯片安装nginx 并且部署vue项目步骤详解
2021/11/20 Servers