http://www.1990c.com/?p=932php
近在作微信公众平台开发,一口气写了二十几个功能,挺有意思的~
今天来分享一下开发经验~
微信公众平台提供的接口很简单,先看看消息交互流程:
说的通俗一些,用户使用微信发送消息 -> 微信将数据发送给开发者 -> 开发者处理消息并返回数据至微信 -> 微信把返回数据发送给用户,期间数据交互经过XML完成,就这么简单。
下面写个实例,开发微信智能聊天机器人:
1. 注册微信公众平台帐号json
微信公众平台:
https://mp.weixin.qq.com/服务器
注: 目前一张身份证只能注册两个帐号,帐号名称关乎加V认证,请慎重注册。
2. 申请服务器/虚拟主机
没有服务器/虚拟主机的童鞋可使用BAE和SAE,很少介绍。
3. 开启开发者模式
微信公众平台有两个模式,一个是编辑模式(傻瓜模式),简单但功能单一。另外一个是开发者模式,能够经过开发实现复杂功能。两个模式互斥,显而易见,登陆微信公众平台并经过“高级功能”菜单开启开发者模式。
4. 填写接口配置信息
一样是在“高级功能”菜单中配置,须要配置两项参数:
URL: 开发者应用访问地址,目前仅支持80端口,以“http://www.1990c.com/weixin/index.php”为例。
TOKEN: 随意填写,用于生成签名,以“1990c”为例。
填写完把下面代码保存为index.php并上传至http://www.1990c.com/weixin/目录,最后点击“提交”完成验证。微信
01 |
<?php |
02 |
define( "TOKEN" , "1990c" ); //TOKEN值 |
03 |
$wechatObj = new wechat(); |
04 |
$wechatObj ->valid(); |
05 |
class wechat { |
06 |
public function valid() { |
07 |
$echoStr = $_GET [ "echostr" ]; |
08 |
if ( $this ->checkSignature()){ |
09 |
echo $echoStr ; |
10 |
exit ; |
11 |
} |
12 |
} |
13 |
14 |
private function checkSignature() { |
15 |
$signature = $_GET [ "signature" ]; |
16 |
$timestamp = $_GET [ "timestamp" ]; |
17 |
$nonce = $_GET [ "nonce" ]; |
18 |
$token = TOKEN; |
19 |
$tmpArr = array ( $token , $timestamp , $nonce ); |
20 |
sort( $tmpArr ); |
21 |
$tmpStr = implode( $tmpArr ); |
22 |
$tmpStr = sha1( $tmpStr ); |
23 |
if ( $tmpStr == $signature ) { |
24 |
return true; |
25 |
} else { |
26 |
return false; |
27 |
} |
28 |
} |
29 |
} |
30 |
?> |
这玩意儿就是微信公众平台校验URL是否正确接入,研究代码没有实质性意义,验证完便可删除文件,就不详细说明了,有兴趣的童鞋能够查看官方文档。cookie
微信公众平台API文档:
http://mp.weixin.qq.com/wiki/index.php微信公众平台
5. 开发微信公众平台功能
OK,上面提到了,微信公众平台与开发者之间的数据交互是经过XML完成的,既然用到XML,固然得遵循规范,因此在着手开发以前先看看官方接口文档提供的XML规范,以文本消息为例:
当用户向微信公众帐号发送消息时,微信服务器会POST给开发者一些数据:curl
01 |
< xml > |
02 |
<!--开发者微信号--> |
03 |
< ToUserName > <![CDATA[toUser]]> </ ToUserName > |
04 |
<!--发送方账号(OpenID)--> |
05 |
< FromUserName > <![CDATA[fromUser]]> </ FromUserName > |
06 |
<!--消息建立时间 (整型)--> |
07 |
< CreateTime >12345678</ CreateTime > |
08 |
<!--消息类别 (text文本消息)--> |
09 |
< MsgType ><![CDATA1]></ MsgType > |
10 |
<!--消息内容--> |
11 |
< Content > <![CDATA[content]]> </ Content > |
12 |
<!--消息ID (64位整型)--> |
13 |
< MsgId >1234567890123456</ MsgId > |
14 |
</ xml > |
开发者在处理完消息后须要返回数据给微信服务器:post
01 |
< xml > |
02 |
<!--接收方账号(OpenID)--> |
03 |
< ToUserName > <![CDATA[toUser]]> </ ToUserName > |
04 |
<!--开发者微信号--> |
05 |
< FromUserName > <![CDATA[fromUser]]> </ FromUserName > |
06 |
<!--消息建立时间 (整型)--> |
07 |
< CreateTime >12345678</ CreateTime > |
08 |
<!--消息类别 (text文本消息)--> |
09 |
< MsgType ><![CDATA1]></ MsgType > |
10 |
<!--回复消息内容--> |
11 |
< Content > <![CDATA[content]]> </ Content > |
12 |
<!--星标操做(位0x0001被标志时 星标刚收到的消息)--> |
13 |
< FuncFlag >0</ FuncFlag > |
14 |
</ xml > |
除文本消息外,微信公众平台还支持用户发送图片消息、地理位置消息、连接消息、事件推送,而开发者还能够向微信公众平台回复音乐消息和图文消息,各种消息XML规范也能够参见官方文档。
来看看官方提供的一个PHP示例,我作了一些精简:this
01 |
<?php |
02 |
$wechatObj = new wechat(); |
03 |
$wechatObj ->responseMsg(); |
04 |
class wechat { |
05 |
public function responseMsg() { |
06 |
07 |
//---------- 接 收 数 据 ---------- // |
08 |
09 |
$postStr = $GLOBALS [ "HTTP_RAW_POST_DATA" ]; //获取POST数据 |
10 |
11 |
//用SimpleXML解析POST过来的XML数据 |
12 |
$postObj = simplexml_load_string( $postStr , 'SimpleXMLElement' ,LIBXML_NOCDATA); |
13 |
14 |
$fromUsername = $postObj ->FromUserName; //获取发送方账号(OpenID) |
15 |
$toUsername = $postObj ->ToUserName; //获取接收方帐号 |
16 |
$keyword = trim( $postObj ->Content); //获取消息内容 |
17 |
$time = time(); //获取当前时间戳 |
18 |
19 |
20 |
//---------- 返 回 数 据 ---------- // |
21 |
22 |
//返回消息模板 |
23 |
$textTpl = "<xml> |
24 |
<ToUserName><![CDATA[%s]]></ToUserName> |
25 |
<FromUserName><![CDATA[%s]]></FromUserName> |
26 |
<CreateTime>%s</CreateTime> |
27 |
<MsgType><![CDATA[%s]]></MsgType> |
28 |
<Content><![CDATA[%s]]></Content> |
29 |
<FuncFlag>0</FuncFlag> |
30 |
</xml>"; |
31 |
32 |
$msgType = "text" ; //消息类型 |
33 |
$contentStr = 'http://www.1990c.com' ; //返回消息内容 |
34 |
35 |
//格式化消息模板 |
36 |
$resultStr = sprintf( $textTpl , $fromUsername , $toUsername , |
37 |
$time , $msgType , $contentStr ); |
38 |
echo $resultStr ; //输出结果 |
39 |
} |
40 |
} |
41 |
?> |
把代码保存为index.php并上传至http://www.1990c.com/weixin/目录,若是刚才没删除该文件,则直接覆盖。
如今用户经过微信公众平台发送任何消息公众帐号均会返回一条内容为“http://www.1990c.com”的消息。
接下来须要作的就是根据用户消息动态返回结果~
SimSimi(小黄鸡)是目前比较火的聊天机器人,我用CURL开发了一个免费的SimSimi(小黄鸡)接口,传入关键词会返回文本回复,这部分不是本文重点,就很少说明,直接上代码:url
01 |
<?php |
02 |
function SimSimi( $keyword ) { |
03 |
04 |
//----------- 获取COOKIE ----------// |
05 |
$url = "http://www.simsimi.com/" ; |
06 |
$ch = curl_init( $url ); |
07 |
curl_setopt( $ch , CURLOPT_HEADER,1); |
08 |
curl_setopt( $ch , CURLOPT_RETURNTRANSFER,1); |
09 |
$content = curl_exec( $ch ); |
10 |
list( $header , $body ) = explode ( "\r\n\r\n" , $content ); |
11 |
preg_match( "/set\-cookie:([^\r\n]*);/iU" , $header , $matches ); |
12 |
$cookie = $matches [1]; |
13 |
curl_close( $ch ); |
14 |
15 |
//----------- 抓 取 回 复 ----------// |
16 |
$url = "http://www.simsimi.com/func/req?lc=ch&msg=$keyword" ; |
17 |
$ch = curl_init( $url ); |
18 |
curl_setopt( $ch , CURLOPT_REFERER, "http://www.simsimi.com/talk.htm?lc=ch" ); |
19 |
curl_setopt( $ch , CURLOPT_RETURNTRANSFER,1); |
20 |
curl_setopt( $ch , CURLOPT_COOKIE, $cookie ); |
21 |
$content = json_decode(curl_exec( $ch ),1); |
22 |
curl_close( $ch ); |
23 |
24 |
if ( $content [ 'result' ]== '100' ) { |
25 |
$content [ 'response' ]; |
26 |
return $content [ 'response' ]; |
27 |
} else { |
28 |
return '我还不会回答这个问题...' ; |
29 |
} |
30 |
} |
31 |
?> |
把上面两段代码整合在一块儿就大功告成了,须要说明一点,微信服务器在5秒内收不到响应会断掉链接,经过此接口有可能会超时,且SimSimi已经屏蔽了BAE和SAE上的抓取请求,推荐使用SimSimi官方收费API,速度比较快~
最后附上微信公众平台智能聊天机器人源码:
微信公众平台智能聊天机器人源码下载:
http://www.1990c.com/wp-content/uploads/2013/05/40.rar