侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

php微信公众号开发之欢迎老朋友

微信(小程序)  /  管理员 发布于 7年前   197

本文实例为大家分享了php微信公众号开发之欢迎老朋友的具体代码,供大家参考,具体内容如下

介绍数据库

  • insert
  • iconv 进行数据库转码函数
  • fromusername 

 

关键代码如下:

$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);$fromUsername = $postObj->FromUserName;$toUsername = $postObj->ToUserName;$keyword = trim($postObj->Content);$time = time();$textTpl = "                  %s                    0    ";       if(!empty( $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函数操作进行数据库操作       */       $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);       $msgType = "text";       if ($c==$fromUsername)       {         $contentStr = "欢迎老朋友!";       }else{        $sql="INSERT INTO `welcome`(`id`,`user`) VALUES (NULL,'{$fromUsername}')";  mysql_query($sql);$contentStr = "欢迎新朋友!";       }       $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);    echo $resultStr;       mysql_close($db);     }else{         echo "Input something..."; }

index.php代码如下

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 = "      %s      0  ";          if(!empty( $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函数操作进行数据库操作           */           $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);           $msgType = "text";           if ($c==$fromUsername)           { $contentStr = "欢迎老朋友!";           }else{$sql="INSERT INTO `welcome`(`id`,`user`) VALUES (NULL,'{$fromUsername}')";mysql_query($sql);$contentStr = "欢迎新朋友!";           }           $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判断用户是否关注微信公众号
  • 微信公众号判断用户是否已关注php代码解析


  • 上一条:
    php微信公众号开发之音乐信息
    下一条:
    php微信公众号开发之秒杀
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 微信模板消息改版后发送规则记录(微信订阅消息参数值内容限制说明)(1个评论)
    • 微信支付v3对接所需工具及命令(0个评论)
    • 2023年9月1日起:微信小程序必须备案才能上线运营(0个评论)
    • 腾讯官方客服回应了:微信好友上限约10000个!(1个评论)
    • 2023年做微信小程序的老铁注意:新增收费项、微信小程序获取手机号也收费了(2个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2017-10
    • 2018-01
    • 2020-03
    • 2021-06
    • 2021-10
    • 2022-03
    • 2023-02
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-10
    • 2023-11
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客