在这篇微信公众平台开发教程中,我们假定你已经有了PHP语言程序、MySQL数据库、计算机网络通讯、及HTTP/XML/CSS/JS等基础。

我们将使用微信公众账号方倍工作室作为讲解的例子,二维码见底部。

本系列教程将引导你完成如下任务:

  1. 申请百度云平台资源
  2. 启用微信公众平台开发模式
  3. 接收、发送、事件消息类型详解
  4. 获取接收到的五种消息
  5. 回复文本、图文、音乐
  6. 小黄鸡聊天机器人开发
  7. 亲子鉴定、情侣相、夫妻相应用开发
  8. 在线点歌应用开发
  9. 微网站开发

 

第一篇 申请服务器资源

创建百度云应用

申请账号

登录​​http://developer.baidu.com/bae​​ ,使用邮箱或者手机注册一个账号,注册需要同时绑定手机并且验证邮箱。

 

创建应用

注册并登录成功以后,点击右上侧的[转]微信公众平台消息接口开发(1)启用接口_开发模式,弹出如下窗口。

[转]微信公众平台消息接口开发(1)启用接口_微信公众平台_02

应用名称自己随便填写一个,接入方式选择“手机web应用”,然后点击确定。



说明:在以下的教程中,您可以将所有我填写为pondbay的地方改为你的一个相应的名称,如果您没有想好名称,最简单的方法就是qq这两个字符+qq号码,比如方倍工作室的QQ是1354386063,那么就将"pondbay"改为"qq1354386063"


[转]微信公众平台消息接口开发(1)启用接口_微信公众平台_03

选择“云环境(BAE)”,

[转]微信公众平台消息接口开发(1)启用接口_javascript_04

在新的窗口中,填写应用域名的名称,环境类型选择PHP,其他根据自己需要选择或者使用上图默认值,然后点击确定



注意:此处填写的域名将要在下面填写URL时用到。可以先保存下来。


原文:javascript:void(0)

创建版本

[转]微信公众平台消息接口开发(1)启用接口_开发模式_05

在版本管理中,点击创建新版本

[转]微信公众平台消息接口开发(1)启用接口_xml_06

版本号填写0,然后保存。

原文:javascript:void(0)

上传代码

将以下代码中的token改为你的名称,并另存为index.php。



注意:此处填写的Token将要在下面填写URL时用到。可以先保存下来。



[转]微信公众平台消息接口开发(1)启用接口_xml_07

<?php

CopyRight 2013 www.doucube.com All Rights Reserved
*/

define("TOKEN", "pondbay");
$wechatObj = new wechatCallbackapiTest();
if (isset($_GET['echostr'])) {
$wechatObj->valid();
}else{
$wechatObj->responseMsg();
}

class wechatCallbackapiTest
{
public function valid()
{
$echoStr = $_GET["echostr"];
if($this->checkSignature()){
echo $echoStr;
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;
}
}

public function responseMsg()
{
$postStr = $GLOBALS["HTTP_RAW_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 = "<xml>
<ToUserName><![CDATA[%s]]></ToUserName>
<FromUserName><![CDATA[%s]]></FromUserName>
<CreateTime>%s</CreateTime>
<MsgType><![CDATA[%s]]></MsgType>
<Content><![CDATA[%s]]></Content>
<FuncFlag>0</FuncFlag>
</xml>";
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;
}
}
}
?>


[转]微信公众平台消息接口开发(1)启用接口_xml_07


 

然后将其压缩成ZIP格式,不能用RAR格式

[转]微信公众平台消息接口开发(1)启用接口_php_09

这样会生成一个index.zip的文件。

回来版本管理中

[转]微信公众平台消息接口开发(1)启用接口_php_10

选择包上传更新

[转]微信公众平台消息接口开发(1)启用接口_微信公众平台_11

选择刚才压缩好的zip包,点击上传。

[转]微信公众平台消息接口开发(1)启用接口_开发模式_12

确定生效,并且点击 [转]微信公众平台消息接口开发(1)启用接口_微信公众平台_13,点击后如下图。

[转]微信公众平台消息接口开发(1)启用接口_javascript_14

百度云应用的创建就成功了。

 

第二篇 启用开发模式

微信公众平台开发模式

高级功能

微信公众平台地址:​​https://mp.weixin.qq.com​

登录微信公众平台后台,选择高级功能,进入后就看到两种模式

[转]微信公众平台消息接口开发(1)启用接口_php_15

我们需要先关闭编辑模式。点击编辑模式的进入

[转]微信公众平台消息接口开发(1)启用接口_xml_16

滑动关闭

[转]微信公众平台消息接口开发(1)启用接口_开发模式_17

 

开发模式

进入开发模式里面

[转]微信公众平台消息接口开发(1)启用接口_开发模式_18

点击成为开发者

[转]微信公众平台消息接口开发(1)启用接口_javascript_19

弹出URL和Token填写框

[转]微信公众平台消息接口开发(1)启用接口_微信公众平台_20

此处的URL为创建百度云应用的域名,包括后面的duapp.com,而Token为index.php中定义的值。在这篇教程中如下:



URL:     http://pondbay.duapp.com
Token: pondbay


填写如下图,

[转]微信公众平台消息接口开发(1)启用接口_开发模式_21

提交成功

[转]微信公众平台消息接口开发(1)启用接口_微信公众平台_22

再滑动右上角启用按钮。

[转]微信公众平台消息接口开发(1)启用接口_xml_23

恭喜,你成功启用开发模式。

 

自动回复

在上面的例子中,实现了一个发送“?”就能回复当前时间的功能。 效果如下:

[转]微信公众平台消息接口开发(1)启用接口_xml_24

至此,你的微信公众平台账号已经实现自动回复了。