出自微信公众平台开发者文档
跳转到: 导航,
搜索
当用户发送消息给公众号时(或某些特定的用户操作引发的事件推送时),会产生一个POST请求,开发者可以在响应包(Get)中返回特定XML结构,来对该消息进行响应(现支持回复文本、图片、图文、语音、视频、音乐)。严格来说,发送被动响应消息其实并不是一种接口,而是对微信服务器发过来消息的一次回复。
微信服务器在将用户的消息发给公众号的开发者服务器地址(开发者中心处配置)后,微信服务器在五秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次,如果在调试中,发现用户无法收到响应的消息,可以检查是否消息处理超时。关于重试的消息排重,有msgid的消息推荐使用msgid排重。事件类型消息推荐使用FromUserName + CreateTime 排重。
如果开发者希望增强安全性,可以在开发者中心处开启消息加密,这样,用户发给公众号的消息以及公众号被动回复用户消息都会继续加密(但),详见被动回复消息加解密说明。
假如服务器无法保证在五秒内处理并回复,必须做出下述回复,这样微信服务器才不会对此作任何处理,并且不会发起重试(这种情况下,可以使用客服消息接口进行异步回复),否则,将出现严重的错误提示。详见下面说明:
1、(推荐方式)直接回复success
2、直接回复空串(指字节长度为0的空字符串,而不是XML结构体中content字段的内容为空)
一旦遇到以下情况,微信都会在公众号会话中,向用户下发系统提示“该公众号暂时无法提供服务,请稍后再试”:
1、开发者在5秒内未回复任何内容
2、开发者回复了异常数据,比如JSON数据等
另外,请注意,回复图片等多媒体消息时需要预先通过素材管理接口上传临时素材到微信服务器,可以使用素材管理中的临时素材,也可以使用永久素材。
各消息类型需要的XML数据包结构如下。
回复文本消息
12345678
参数
是否必须
描述
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间 (整型)
MsgType
是
text
Content
是
回复的消息内容(换行:在content中能够换行,微信客户端就支持换行显示)
回复图片消息
12345678
参数
是否必须
说明
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间 (整型)
MsgType
是
image
MediaId
是
通过素材管理接口上传多媒体文件,得到的id。
回复语音消息
12345678
参数
是否必须
说明
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间戳 (整型)
MsgType
是
语音,voice
MediaId
是
通过素材管理接口上传多媒体文件,得到的id
回复视频消息
12345678
参数
是否必须
说明
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间 (整型)
MsgType
是
video
MediaId
是
通过素材管理接口上传多媒体文件,得到的id
Title
否
视频消息的标题
Description
否
视频消息的描述
回复音乐消息
12345678
参数
是否必须
说明
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间 (整型)
MsgType
是
music
Title
否
音乐标题
Description
否
音乐描述
MusicURL
否
音乐链接
HQMusicUrl
否
高质量音乐链接,WIFI环境优先使用该链接播放音乐
ThumbMediaId
否
缩略图的媒体id,通过素材管理接口上传多媒体文件,得到的id
回复图文消息
12345678
2
参数
是否必须
说明
ToUserName
是
接收方帐号(收到的OpenID)
FromUserName
是
开发者微信号
CreateTime
是
消息创建时间 (整型)
MsgType
是
news
ArticleCount
是
图文消息个数,限制为10条以内
Articles
是
多条图文消息信息,默认第一个item为大图,注意,如果图文数超过10,则将会无响应
Title
否
图文消息标题
Description
否
图文消息描述
PicUrl
否
图片链接,支持JPG、PNG格式,较好的效果为大图360*200,小图200*200
Url
否
点击图文消息跳转链接