设为首页收藏本站

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 164|回复: 0

微信公众平台开发(二) 微信公众平台示例代码分析

[复制链接]
发表于 2014-1-22 09:04:40 | 显示全部楼层 |阅读模式
一、摘要
微信公众平台提供了一个简单的php示例代码,在做进一步开发之前,我们有必要将其详细了解一下。
二、获取代码
微信官网:http://mp.weixin.qq.com/mpres/htmledition/res/wx_sample.zip
三、分析代码
完整代码如下:
  1. <?php
  2. /**
  3.   * wechat php test
  4.   */

  5. //define your token
  6. define("TOKEN", "weixin");
  7. $wechatObj = new wechatCallbackapiTest();
  8. $wechatObj->valid();

  9. class wechatCallbackapiTest
  10. {
  11.     public function valid()
  12.     {
  13.         $echoStr = $_GET["echostr"];

  14.         //valid signature , option
  15.         if($this->checkSignature()){
  16.             echo $echoStr;
  17.             exit;
  18.         }
  19.     }

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

  24.         //extract post data
  25.         if (!empty($postStr)){
  26.                
  27.                 $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
  28.                 $fromUsername = $postObj->FromUserName;
  29.                 $toUsername = $postObj->ToUserName;
  30.                 $keyword = trim($postObj->Content);
  31.                 $time = time();
  32.                 $textTpl = "<xml>
  33.                             <ToUserName><![CDATA[%s]]></ToUserName>
  34.                             <FromUserName><![CDATA[%s]]></FromUserName>
  35.                             <CreateTime>%s</CreateTime>
  36.                             <MsgType><![CDATA[%s]]></MsgType>
  37.                             <Content><![CDATA[%s]]></Content>
  38.                             <FuncFlag>0</FuncFlag>
  39.                             </xml>";            
  40.                 if(!empty( $keyword ))
  41.                 {
  42.                     $msgType = "text";
  43.                     $contentStr = "Welcome to wechat world!";
  44.                     $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
  45.                     echo $resultStr;
  46.                 }else{
  47.                     echo "Input something...";
  48.                 }

  49.         }else {
  50.             echo "";
  51.             exit;
  52.         }
  53.     }
  54.         
  55.     private function checkSignature()
  56.     {
  57.         $signature = $_GET["signature"];
  58.         $timestamp = $_GET["timestamp"];
  59.         $nonce = $_GET["nonce"];   
  60.                
  61.         $token = TOKEN;
  62.         $tmpArr = array($token, $timestamp, $nonce);
  63.         sort($tmpArr);
  64.         $tmpStr = implode( $tmpArr );
  65.         $tmpStr = sha1( $tmpStr );
  66.         
  67.         if( $tmpStr == $signature ){
  68.             return true;
  69.         }else{
  70.             return false;
  71.         }
  72.     }
  73. }

  74. ?>
复制代码


3.1 整体分析
原始示例代码大致分为四个部分:
  • 定义TOKEN
  • 声明一个类 wechatCallbackapiTest
  • 创建类wechatCallbackapiTest 的一个实例对象 $wechatObj
  • 调用类的 valid() 方法。
3.2 详细分析
3.2.1 定义TOKEN
define("TOKEN", "weixin");
define 是用来给常量赋值的函数,这句话的意思是赋予“TOKEN”这个常量值为“weixin”。
TOKEN 是用来进行交互安全认证的,开发者可以随意定义,要和公众平台里设置的一样。
3.2.2 声明一个类
class wechatCallbackapiTest{
}
声明一个类 wechatCallbackapiTest,该类中包含有三个方法(函数)。
a. public function valid()
用于申请 成为开发者 时向微信发送验证信息。
b. public function responseMsg()
处理并回复用户发送过来的消息,也是用的最多的一个函数,几乎所有的功能都在这里实现。
  1. responseMsg 函数详解:

  2. $postStr = $GLOBALS["HTTP_RAW_POST_DATA"];
  3. 接收微信公众平台发送过来的用户消息,该消息数据结构为XML,不是php默认的识别数据类型,因此这里用了$GLOBALS['HTTP_RAW_POST_DATA']来接收,同时赋值给了$postStr

  4. if (!empty($postStr))
  5. 判断$postStr是否为空,如果不为空(接收到了数据),就继续执行下面的语句;如果为空,则跳转到与之相对应的else语句。

  6. $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
  7. 使用simplexml_load_string() 函数将接收到的XML消息数据载入对象$postObj中。这个严谨的写法后面还得加个判断是否载入成功的条件语句,不过不写也没事。

  8. $fromUsername = $postObj->FromUserName;
  9. 将对象$postObj中的发送消息用户的OPENID赋值给$fromUsername变量

  10. $toUsername = $postObj->ToUserName;
  11. 将对象$postObj中的公众账号的ID赋值给$toUsername变量

  12. $keyword = trim($postObj->Content);
  13. trim() 函数从字符串的两端删除空白字符和其他预定义字符,这里就可以得到用户输入的关键词

  14. $time = time();
  15. time() 函数返回当前时间的 Unix 时间戳,即自从 Unix 纪元(格林威治时间 1970 年 1 月 1 日 00:00:00)到当前时间的秒数。

  16. $textTpl = "<xml>
  17.        <ToUserName><![CDATA[%s]]></ToUserName>
  18.        <FromUserName><![CDATA[%s]]></FromUserName>
  19.         <CreateTime>%s</CreateTime>
  20.        <MsgType><![CDATA[%s]]></MsgType>
  21.        <Content><![CDATA[%s]]></Content>
  22.        <FuncFlag>0</FuncFlag>
  23.        </xml>";
  24. 存放微信输出内容的模板

  25. if(!empty( $keyword ))
  26. 判断$keyword是否为空,不为空则继续执行下面的语句;如果为空,则跳转到与之相对应的else语句,即 echo "Input something...";

  27. $msgType = "text";
  28. 消息类型是文本类型

  29. $contentStr = "Welcome to wechat world!";
  30. 回复的消息内容

  31. $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
  32. 使用sprintf() 函数将格式化的数据写入到变量中去;
  33. $fromUsername, $toUsername, $time, $msgType, $contentStr 分别顺序替换模板里“%s”位置,也即是“$resultStr”这个变量最后实际为:
  34. <xml>
  35.                                                         <ToUserName><![CDATA[$toUsername]]></ToUserName>
  36.                                                         <FromUserName><![CDATA[$fromUsername]]></FromUserName>
  37.                                                         <CreateTime>$time</CreateTime>
  38.                                                         <MsgType><![CDATA[$msgType]]></MsgType>
  39.                                                         <Content><![CDATA[$contentStr]]></Content>
  40.                                                         <FuncFlag>0</FuncFlag>      //位0x0001被标志时,星标刚收到的消息。
  41.                                                         </xml>
  42. echo $resultStr;     //把回复的消息输出
复制代码

. private function checkSignature()
开发者通过检验signature对请求进行校验(下面有校验方式)。若确认此次GET请求来自微信服务器,请求原样返回echostr参数内容,则接入生效,否则接入失败。
signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
加密/校验流程:
1. 将token、timestamp、nonce三个参数进行字典序排序
2. 将三个参数字符串拼接成一个字符串进行sha1加密
3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信

3.2.3 创建实例对象
$wechatObj = new wechatCallbackapiTest();
3.2.4 调用类方法验证
$wechatObj->valid();
调用类的valid()方法执行接口验证,接口设置成功后将其注释掉。
四、总结
以上是对微信官方示例代码的一个分析,有解释不对的地方,还请高手指出。另外,该代码只是官方给出的简单示例代码,如果要做复杂的开发,还是要求开发者按照严谨的开发模式改写该段代码,会在后续教程中娓娓道来。
五、参考
微信官方公众平台API文档:http://mp.weixin.qq.com/wiki/index.php

卓锦苏州 基于BAE 平台开发,针对于主流的微信功能进行开发测试。





您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|小黑屋|BC Morning Website ( Best Deal Inc. 001 )  

GMT-8, 2025-8-26 09:08 , Processed in 0.014307 second(s), 17 queries .

Supported by Best Deal Online X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表