微信接口开发小记。

创建过程就需要做签名校验,描述如下:

 

公众平台用户提交信息后,我们将以GET请求方式请求到填写的Url上,并且带上四个参数:

* signature — 微信加密签名

* timestamp — 时间戳

* nonce — 随机数

* echostr — 随机字符串

开发者通过检验signature对网址接入合法性进行校验。若此次GET请求原样返回echostr参数内容,则接入生效,否则接入失败。验证signature将结合开发者填写的token参数、timestamp参数和nonce参数等,加密流程:

* 将token、timestamp、nonce三个参数进行字典序排序

* 将三个参数字符串拼接成一个字符串进行SHA1加密

* 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信。

代码:

 

  
  
  
  
  1. <?  
  2.         $signature = $_GET['signature'];  
  3.         $timestamp = $_GET['timestamp'];  
  4.         $nonce = $_GET['nonce'];      
  5.                   
  6.         $token = TOKEN;  
  7.         $tmpArr = array($token$timestamp$nonce);  
  8.         sort($tmpArr);  
  9.         $tmpStr = implode( $tmpArr );  
  10.         $tmpStr = sha1( $tmpStr );  
  11.           
  12.         if$tmpStr == $signature ){  
  13.             return $_GET['echostr'];  
  14.         }else{  
  15.             return false;  
  16.         }  
  17. ?> 

然而,微信不走json途径传递数据:

 

所以要用simplexml_load_string装XML数据为对象,另外发现POST方法不是urlencode,所以设置HTTP_RAW_POST_DATA,然后可以读取数据.

ToUserName 消息接收方微信号,一般为公众平台账号微信号

FromUserName 消息发送方微信号

CreateTime 消息创建时间

MsgType 文本消息为text

Content 消息内容

  
  
  
  
  1. <?php
  2. $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; //符合微信的POST规范
  3. if (!emptyempty($postStr))
  4. {
  5. $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); //XML转对象函数,可能最近这一两年入行的不太清楚XML函数
  6. //数据从对象取出
  7. $fromUsername = $postObj->FromUserName;
  8. $toUsername = $postObj->ToUserName;
  9. $CreateTime = $postObj->CreateTime;
  10. $MsgType = $postObj->MsgType;
  11. $Content = $postObj->Content;
  12. $keyword = trim($postObj->Content); //安全Trim
  13. $time = time();
  14. //XML数据体
  15. $textTpl = "<xml>
  16. <ToUserName><![CDATA[%s]]></ToUserName>
  17. <FromUserName><![CDATA[%s]]></FromUserName>
  18. <CreateTime>%s</CreateTime>
  19. <MsgType><![CDATA[%s]]></MsgType>
  20. <Content><![CDATA[%s]]></Content>
  21. <FuncFlag>0</FuncFlag>
  22. </xml>";
  23. if(!emptyempty( $keyword )) //如果发信息来了,不是空白POST,微信规定立即回复,不用推送.
  24. {
  25. $msgType = "text"; //定义类型
  26. $contentStr = "Hello World,I am Tater!"; //回复
  27. $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); //记住,Tpl是要载入的
  28. echo $resultStr; //输出,以便微信抓!
  29. }
  30. else
  31. {
  32. echo "What are you say!"; //输入信息有问题,提示输入!
  33. }
  34. }
  35. else
  36. {
  37. echo "";
  38. exit;
  39. }
  40. ?>

你可能感兴趣的:(微信api)