在阅读这篇文章之前你要做以下的准备:
1.注册一个订阅号(通过微信公众平台https://mp.weixin.qq.com/);
2.注册新浪云并实名认证http://sae.sina.com.cn/
3.实名认证新浪云之后,创建一个云应用.
4.你需要知道php基础知识.
第一步:填写服务器配置
我们登录微信公众号之后,右下角基本开发配置点进去
---->
URL是开发者用来接收微信消息和事件的接口URL.具体怎么填我们等下详细说.
---->
Token可以随意填写(但是每个人都不一样的,如果后面提交失败可以试着修改Token),这个Token会和接口中包含的Token进行比对,从而验证安全性,EncodingAESKey由开发者手动填写或随机生成,将用作消息体加解密密钥。
---->
填写的URL,需要我们有自己的服务器的地址,服务器可以自己购买也可以用免费的云服务器(新浪云应用或者百度云应用),现在我们就要到我们之前注册的新浪云云应用了.
---->
1.登录新浪云,点击云应用,点击进入控制台.
2.级域名和应用名称,自己起个名字就好.然后点击进入应用信息.
3.之后点击进入编辑代码
4.之后会弹出SAE的界面,我们需要在里面建立一个php文件,然后点击通过URL访问,之后我们把这个网址拷贝下来,放到我们之前基本配置的URL上.(如果是自己购买的虚拟服务器,则在基本配置的URL上填写自定义php文件的URL地址即可。)
---->
令牌(Token)可以自定义填写,每个人的token都不一样。
---->
消息加解密密钥(EncodingAESKey):随机生成。
第二步:验证消息的确来自微信服务器
接下来我们就要编辑创建好的php文件了。
具体的php代码如下:<?php
/**
* wechat php test
*/
//define your token
define("TOKEN", "weixin");
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid();
//$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;
$keyword = trim($postObj->Content);
$time = time();
$textTpl = "
%s
0
";
//如果内容不为空
/* if(!empty( $keyword ))
{
$msgType = "text";
$contentStr = "Welcome to wechat world!";
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
echo $resultStr;
}else{
echo "Input something...";
}*/
//如果内容不为‘?’
if($keyword == "?" || $keyword == "?")
{
$msgType = "text";
$contentStr = date("Y-m-d H:i:s",time());
$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr);
echo $resultStr;
}
}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;
}
}
}
?>
1.必须对SDK代码做一点点修改,原来SDK代码只调用了签名,根本没有调用responseMsg()方法。只需要在代码开始添加调用代码即可,开头部分代码如下:
//define your token
define("TOKEN", "weixin"); //TOKEN和你在公众接口里设置的一样比如weixin,
$wechatObj = new wechatCallbackapiTest();
$wechatObj->valid(); //接口设置成功后把//$wechatObj->valid();注释掉(12月31日修订)
$wechatObj->responseMsg(); //就是添加这段调用代码
一切就绪后随便向平台发送个消息,然后就会显示了,注意平台发送内容编码格式是“UTF-8”
2.深入开发。所有数据处理都可以在responseMsg方法中完成,你想怎么做都可以。
3.注意事项,返回消息长度限制2048个字节。
4.如果你的关键词不多,可以不使用接口,直接定义关键词,和回复内容即可(做多200条规则)。
Php代码分析:
一、声明一个类
class wechatCallbackapiTest{
}
声明一个类 wechatCallbackapiTest,该类中包含有三个方法(函数)。
a. public function valid()
用于申请 成为开发者 时向微信发送验证信息。
b. public function responseMsg()
处理并回复用户发送过来的消息,也是用的最多的一个函数,几乎所有的功能都在这里实现。
c. private function checkSignature()
开发者通过检验signature对请求进行校验(下面有校验方式)。若确认此次GET请求来自微信服务器,请求原样返回echostr参数内容,则接入生效,否则接入失败。
signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
加密/校验流程:
1. 将token、timestamp、nonce三个参数进行字典序排序
2. 将三个参数字符串拼接成一个字符串进行sha1加密
3. 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
3.2.3 创建实例对象
$wechatObj = new wechatCallbackapiTest();
第三步:上传php文件到服务器
设置好自己的微信公众平台消息接口,这个大家参照网站提示设置即可
注意先要上传API示范文件(注意验证签名的时候文件格式用ANSI,不要修改,签名通过了建议修改为UTF-8格式,记事本打开另存的时候可以选择文件存储编码格式,不是网页格式哦),修改weixin为自己的token,即api的TOKEN和自己平台的是一致的,然后点击提交,如果正确会,显示"提交成功”(注意事项:为什么自己创建的index.php代码和示例代码相同,但是验证签名不能通过呢?应为很多软件创建的文件都包含BOM,PHP不支持,所以要报BOM去掉(示例代码已经去BOM了),可以使用UE,或者Linux VI set nobomb命令。)
注意URL网址对应的必须是接口处理文件比如:http://www.abc.com/weichat/默认页面是index.php,那么可以把帮助中的示例代码下载下来wx_sample.php修改为index.php然后上传到网站weichat目录下。
参考:
微信官方公众平台API文档:http://mp.weixin.qq.com/wiki/index.php
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。