欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

微信公众平台开发教程(二) 基本原理及消息接口总结

程序员文章站 2022-06-21 08:47:09
一、基本原理 在开始做之前,大家可能对这个很感兴趣,但是又比较茫然。是不是很复杂?很难学啊? 其实恰恰相反,很简单。为了打消大家的顾虑,先简单介绍了微信公众平台的基本原...

一、基本原理

在开始做之前,大家可能对这个很感兴趣,但是又比较茫然。是不是很复杂?很难学啊?

其实恰恰相反,很简单。为了打消大家的顾虑,先简单介绍了微信公众平台的基本原理。

微信服务器就相当于一个转发服务器,终端(手机、pad等)发起请求至微信服务器,微信服务器,然后将请求转发给自定义服务(这就里就是我们的具体实现)。

服务处理完毕,然后挥发给微信服务器,微信服务器再将具体响应回复到终端。

通信协议为:http

数据格式为:xml

具体的流程如下图所示:

微信公众平台开发教程(二) 基本原理及消息接口总结

其实,我们需要做的事情,就是对http请求,做出响应。

具体的请求内容,我们按照特定的xml格式去解析,处理完毕后,也要按照特定的xml格式返回。

我们只需要一个简单的实现httphandler即可。

当然,微信平台还能实现更加复杂的业务,比如微信可以作为内嵌的浏览器,我们可以通过微信的链接,打开htm界面,然后实现自己的逻辑。

 二、消息接口(官方文档)

申请消息接口

点击,填写网址url和token,其中token可由开发者可以任意填写,用作生成签名。

网址接入

公众平台用户提交信息后,微信服务器将发送get请求到填写的url上,并且带上四个参数:

参数 描述
signature 微信加密签名
timestamp 时间戳
nonce 随机数
echostr 随机字符串

开发者通过检验signature对请求进行校验(下面有校验方式)。若确认此次get请求来自微信服务器,请原样返回echostr参数内容,则接入生效,否则接入失败。

signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
加密/校验流程:

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

2. 将三个参数字符串拼接成一个字符串进行sha1加密

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

消息推送

当普通微信用户向公众账号发消息时,微信服务器将post该消息到填写的url上。结构如下:

文本消息

 <xml>
 <tousername><![cdata[touser]]></tousername>
 <fromusername><![cdata[fromuser]]></fromusername> 
 <createtime>1348831860</createtime>
 <msgtype><![cdata[text]]></msgtype>
 <content><![cdata[this is a test]]></content>
 <msgid>1234567890123456</msgid>
 </xml>

参数 描述
tousername 开发者微信号
fromusername 发送方帐号(一个openid)
createtime 消息创建时间 (整型)
msgtype text
content 文本消息内容
msgid 消息id,64位整型

图片消息

 <xml>
 <tousername><![cdata[touser]]></tousername>
 <fromusername><![cdata[fromuser]]></fromusername>
 <createtime>1348831860</createtime>
 <msgtype><![cdata[image]]></msgtype>
 <picurl><![cdata[this is a url]]></picurl>
 <msgid>1234567890123456</msgid>
 </xml>

参数 描述
tousername 开发者微信号
fromusername 发送方帐号(一个openid)
createtime 消息创建时间 (整型)
msgtype image
picurl 图片链接
msgid 消息id,64位整型

地理位置消息

<xml>
<tousername><![cdata[touser]]></tousername>
<fromusername><![cdata[fromuser]]></fromusername>
<createtime>1351776360</createtime>
<msgtype><![cdata[location]]></msgtype>
<location_x>23.134521</location_x>
<location_y>113.358803</location_y>
<scale>20</scale>
<label><![cdata[位置信息]]></label>
<msgid>1234567890123456</msgid>
</xml>

参数 描述
tousername 开发者微信号
fromusername 发送方帐号(一个openid)
createtime 消息创建时间 (整型)
msgtype location
location_x 地理位置纬度
location_y 地理位置经度
scale 地图缩放大小
label 地理位置信息
msgid 消息id,64位整型

链接消息

<xml>
<tousername><![cdata[touser]]></tousername>
<fromusername><![cdata[fromuser]]></fromusername>
<createtime>1351776360</createtime>
<msgtype><![cdata[link]]></msgtype>
<title><![cdata[公众平台官网链接]]></title>
<description><![cdata[公众平台官网链接]]></description>
<url><![cdata[url]]></url>
<msgid>1234567890123456</msgid>
</xml>

参数 描述
tousername 接收方微信号
fromusername 发送方微信号,若为普通用户,则是一个openid
createtime 消息创建时间
msgtype 消息类型,link
title 消息标题
description 消息描述
url 消息链接
msgid 消息id,64位整型

事件推送

事件推送只支持微信4.5版本,目前开启自定义菜单接口事件推送、关注与取消关注事件推送。其余功能即将开放,敬请期待。

<xml><tousername><![cdata[touser]]></tousername>
<fromusername><![cdata[fromuser]]></fromusername>
<createtime>123456789</createtime>
<msgtype><![cdata[event]]></msgtype>
<event><![cdata[event]]></event>
<eventkey><![cdata[eventkey]]></eventkey>
</xml>

参数 描述
tousername 接收方微信号
fromusername 发送方微信号,若为普通用户,则是一个openid
createtime 消息创建时间
msgtype 消息类型,event
event 事件类型,subscribe(订阅)、unsubscribe(取消订阅)、click(自定义菜单点击事件)
eventkey 事件key值,与自定义菜单接口中key值对应

消息回复

对于每一个post请求,开发者在响应包中返回特定xml结构,对该消息进行响应(现支持回复文本、图文、语音、视频、音乐)。

微信服务器在五秒内收不到响应会断掉连接。

回复xml结构如下:

回复文本消息

 <xml>
 <tousername><![cdata[touser]]></tousername>
 <fromusername><![cdata[fromuser]]></fromusername>
 <createtime>12345678</createtime>
 <msgtype><![cdata[text]]></msgtype>
 <content><![cdata[content]]></content>
 </xml>

参数 描述
tousername 接收方帐号(收到的openid)
fromusername 开发者微信号
createtime 消息创建时间
msgtype text
content 回复的消息内容,长度不超过2048字节

回复音乐消息

 <xml>
 <tousername><![cdata[touser]]></tousername>
 <fromusername><![cdata[fromuser]]></fromusername>
 <createtime>12345678</createtime>
 <msgtype><![cdata[music]]></msgtype>
 <music>
 <title><![cdata[title]]></title>
 <description><![cdata[description]]></description>
 <musicurl><![cdata[music_url]]></musicurl>
 <hqmusicurl><![cdata[hq_music_url]]></hqmusicurl>
 </music>
 </xml>

参数 描述
tousername 接收方帐号(收到的openid)
fromusername 开发者微信号
createtime 消息创建时间
msgtype music
musicurl 音乐链接
hqmusicurl 高质量音乐链接,wifi环境优先使用该链接播放音乐

回复图文消息

 <xml>
 <tousername><![cdata[touser]]></tousername>
 <fromusername><![cdata[fromuser]]></fromusername>
 <createtime>12345678</createtime>
 <msgtype><![cdata[news]]></msgtype>
 <articlecount>2</articlecount>
 <articles>
 <item>
 <title><![cdata[title1]]></title> 
 <description><![cdata[description1]]></description>
 <picurl><![cdata[picurl]]></picurl>
 <url><![cdata[url]]></url>
 </item>
 <item>
 <title><![cdata[title]]></title>
 <description><![cdata[description]]></description>
 <picurl><![cdata[picurl]]></picurl>
 <url><![cdata[url]]></url>
 </item>
 </articles>
 </xml>

参数 描述
tousername 接收方帐号(收到的openid)
fromusername 开发者微信号
createtime 消息创建时间
msgtype news
articlecount 图文消息个数,限制为10条以内
articles 多条图文消息信息,默认第一个item为大图
title 图文消息标题
description 图文消息描述
picurl 图片链接,支持jpg、png格式,较好的效果为大图640*320,小图80*80。
url 点击图文消息跳转链接

官方接口文档:http://mp.weixin.qq.com/wiki/index.php?title=%e6%b6%88%e6%81%af%e6%8e%a5%e5%8f%a3%e6%8c%87%e5%8d%97

注意事项

1.用户openid对一个公众号是固定唯一的串

2.请使用80端口

尽请关注:后续我们将全面讲解具体的开发过程。

三、消息类图

微信公众平台开发教程(二) 基本原理及消息接口总结

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。