你的位置:首页 > Java教程

[Java教程]第三篇 :微信公众平台开发实战Java版之请求消息,响应消息以及事件消息类的封装


微信服务器和第三方服务器之间究竟是通过什么方式进行对话的?

下面,我们先看下图:

 

其实我们可以简单的理解:

(1)首先,用户向微信服务器发送消息;

(2)微信服务器接收到用户的消息处理之后,通过开发者配置的URL和Token 来找到第三方服务器,并以

(3)第三方服务器获取这些消息之后,需要按照微信服务器传过来的

(4)微信服务器解析这些

基本就结束了一个基本的请求与相应。

 

 

一、封装请求信息

当普通微信用户向公众账号发消息时,微信服务器将POST消息的

各消息类型的推送

 

 ----------------------------------------------------------------------------------------------------------------------------------------

文本消息 <this is a test]]></Content> <MsgId>1234567890123456</MsgId> </参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  textContent  文本消息内容MsgId  消息id,64位整型 图片消息 <this is a url]]></PicUrl> <MediaId><![CDATA[media_id]]></MediaId> <MsgId>1234567890123456</MsgId> </参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  imagePicUrl  图片链接MediaId  图片消息媒体id,可以调用多媒体文件下载接口拉取数据。MsgId  消息id,64位整型 语音消息<参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  语音为voiceMediaId  语音消息媒体id,可以调用多媒体文件下载接口拉取数据。Format  语音格式,如amr,speex等MsgID  消息id,64位整型 请注意,开通语音识别后,用户每次发送语音给公众号时,微信会在推送的语音消息<多出的字段中,Format为语音格式,一般为amr,Recognition为语音识别结果,使用UTF8编码。视频消息<参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  视频为videoMediaId  视频消息媒体id,可以调用多媒体文件下载接口拉取数据。ThumbMediaId  视频消息缩略图的媒体id,可以调用多媒体文件下载接口拉取数据。MsgId  消息id,64位整型 小视频消息<参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  小视频为shortvideoMediaId  视频消息媒体id,可以调用多媒体文件下载接口拉取数据。ThumbMediaId  视频消息缩略图的媒体id,可以调用多媒体文件下载接口拉取数据。MsgId  消息id,64位整型 地理位置消息< 参数  描述ToUserName  开发者微信号FromUserName  发送方帐号(一个OpenID)CreateTime  消息创建时间 (整型)MsgType  locationLocation_X  地理位置维度Location_Y  地理位置经度Scale  地图缩放大小Label  地理位置信息MsgId  消息id,64位整型 链接消息< 参数  描述ToUserName  接收方微信号FromUserName  发送方微信号,若为普通用户,则是一个OpenIDCreateTime  消息创建时间MsgType  消息类型,linkTitle  消息标题Description  消息描述Url  消息链接MsgId  消息id,64位整型 

View Code

----------------------------------------------------------------------------------------------------------------------------------------

详细的介绍可以参照  官网介绍

 

其中用户可以向微信服务器发送的消息类型大概可以分为:文本消息图片消息语音消息视频消息小视频消息地理位置消息链接消息

根据观察可以知道这些消息中,都会传回来这些公共的字段如:

ToUserName(开发者微信号);

FromUserName(发送方帐 号,OPEN_ID);

CreateTime(消息的创建时间);

MsgType(消息类型);

MsgId(消息ID)。

我们把这些封装成一个基类,然后 不同的部分,分别封装为各自的类,这样提高代码的重用性。

 

这个请求消息的基类是 :BaseMessage :

 

package com.souvc.weixin.message.req;/*** 类名: BaseMessage </br>* 描述: 请求消息的基类 </br>* 开发人员: souvc</br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class BaseMessage {  // 开发者微信号  private String ToUserName;  // 发送方帐号(一个OpenID)  private String FromUserName;  // 消息创建时间 (整型)  private long CreateTime;  // 消息类型(text/image/location/link)  private String MsgType;  // 消息id,64位整型  private long MsgId;    public String getToUserName() {    return ToUserName;  }  public void setToUserName(String toUserName) {    ToUserName = toUserName;  }  public String getFromUserName() {    return FromUserName;  }  public void setFromUserName(String fromUserName) {    FromUserName = fromUserName;  }  public long getCreateTime() {    return CreateTime;  }  public void setCreateTime(long createTime) {    CreateTime = createTime;  }  public String getMsgType() {    return MsgType;  }  public void setMsgType(String msgType) {    MsgType = msgType;  }  public long getMsgId() {    return MsgId;  }  public void setMsgId(long msgId) {    MsgId = msgId;  }}

 

 

(1)文本消息:Content 文本消息内容:

 

package com.souvc.weixin.message.req;/*** 类名: TextMessage </br>* 描述: 请求消息之文本消息 </br>* 开发人员: souvc </br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class TextMessage extends BaseMessage {  // 消息内容  private String Content;  public String getContent() {    return Content;  }  public void setContent(String content) {    Content = content;  }}

 

(2)图片消息:

PicUrl图片链接
MediaId图片消息媒体id,可以调用多媒体文件下载接口拉取数据。

 

 

package com.souvc.weixin.message.req;/*** 类名: ImageMessage </br>* 描述: 请求消息之图片消息 </br>* 开发人员: souvc </br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class ImageMessage extends BaseMessage {  // 图片链接  private String PicUrl;  private String MediaId;  public String getPicUrl() {    return PicUrl;  }  public void setPicUrl(String picUrl) {    PicUrl = picUrl;  }  public String getMediaId() {    return MediaId;  }  public void setMediaId(String mediaId) {    MediaId = mediaId;  }}

 

 

 

(3) 语音消息:

MediaId语音消息媒体id,可以调用多媒体文件下载接口拉取数据。
Format语音格式,如amr,speex等

 

 

package com.souvc.weixin.message.req;/*** 类名: VoiceMessage </br>* 描述: 请求消息之语音消息 </br>* 开发人员: souvc </br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class VoiceMessage extends BaseMessage {  // 媒体ID  private String MediaId;  // 语音格式  private String Format;  public String getMediaId() {    return MediaId;  }  public void setMediaId(String mediaId) {    MediaId = mediaId;  }  public String getFormat() {    return Format;  }  public void setFormat(String format) {    Format = format;  }}

 

 

 

(4)视频消息:

MediaId视频消息媒体id,可以调用多媒体文件下载接口拉取数据。
ThumbMediaId视频消息缩略图的媒体id,可以调用多媒体文件下载接口拉取数据。

 

package com.souvc.weixin.message.req;/*** 类名: VideoMessage </br>* 描述: 请求消息之视频消息 </br>* 开发人员: souvc </br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class VideoMessage extends BaseMessage{  // 媒体ID  private String MediaId;  // 语音格式  private String ThumbMediaId;
public String getMediaId() { return MediaId; } public void setMediaId(String mediaId) { MediaId = mediaId; } public String getThumbMediaId() { return ThumbMediaId; } public void setThumbMediaId(String thumbMediaId) { ThumbMediaId = thumbMediaId; } }

 

 

(5)小视频消息:

MediaId视频消息媒体id,可以调用多媒体文件下载接口拉取数据。
ThumbMediaId视频消息缩略图的媒体id,可以调用多媒体文件下载接口拉取数据。

 

 

(6) 地理位置消息:

Location_X地理位置维度
Location_Y地理位置经度
Scale地图缩放大小
Label地理位置信息

 

package com.souvc.weixin.message.req;/*** 类名: LocationMessage </br>* 描述: 请求消息之地理位置消息 </br>* 开发人员:souvc</br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class LocationMessage extends BaseMessage {    // 地理位置维度  private String Location_X;  // 地理位置经度  private String Location_Y;  // 地图缩放大小  private String Scale;  // 地理位置信息  private String Label;    public String getLocation_X() {    return Location_X;  }  public void setLocation_X(String location_X) {    Location_X = location_X;  }  public String getLocation_Y() {    return Location_Y;  }  public void setLocation_Y(String location_Y) {    Location_Y = location_Y;  }  public String getScale() {    return Scale;  }  public void setScale(String scale) {    Scale = scale;  }  public String getLabel() {    return Label;  }  public void setLabel(String label) {    Label = label;  }}

 

 

(7) 链接消息:

Title消息标题
Description消息描述
Url消息链接

 

 

package com.souvc.weixin.message.req;/*** 类名: LinkMessage </br>* 描述: 请求消息之链接消息 </br>* 开发人员: souvc </br>* 创建时间: Sep 29, 2015 </br>* 发布版本:V1.0 </br> */public class LinkMessage extends BaseMessage {  // 消息标题  private String Title;  // 消息描述  private String Description;  // 消息链接  private String Url;  public String getTitle() {    return Title;  }  public void setTitle(String title) {    Title = title;  }  public String getDescription() {    return Description;  }  public void setDescription(String description) {    Description = description;  }  public String getUrl() {    return Url;  }  public void setUrl(String url) {    Url = url;  }}

 

 

 

二、封装事件

 

在微信用户和公众号产生交互的过程中,用户的某些操作会使得微信服务器通过事件推送的形式通知到开发者在开发者中心处设置的服务器地址,从而开发者可以获取到该信息。

事件的数据格式为:

 

关注/取消关注事件用户在关注与取消关注公众号时,微信会把这个事件推送到开发者填写的URL。方便开发者给用户下发欢迎消息或者做帐号的解绑。 微信服务器在五秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次 关于重试的消息排重,推荐使用FromUserName + CreateTime 排重。 假如服务器无法保证在五秒内处理并回复,可以直接回复空串,微信服务器不会对此作任何处理,并且不会发起重试。 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,subscribe(订阅)、unsubscribe(取消订阅) 使用网页调试工具调试该接口 扫描带参数二维码事件用户扫描带场景值二维码时,可能推送以下两种事件: 1. 如果用户还未关注公众号,则用户可以关注公众号,关注后微信会将带场景值关注事件推送给开发者。 2. 如果用户已经关注公众号,则微信会将带场景值扫描事件推送给开发者。 1. 用户未关注时,进行关注后的事件推送 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,subscribe EventKey 事件KEY值,qrscene_为前缀,后面为二维码的参数值 Ticket 二维码的ticket,可用来换取二维码图片 2. 用户已关注时的事件推送 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,SCAN EventKey 事件KEY值,是一个32位无符号整数,即创建二维码时的二维码scene_id Ticket 二维码的ticket,可用来换取二维码图片 使用网页调试工具调试该接口 上报地理位置事件用户同意上报地理位置后,每次进入公众号会话时,都会在进入时上报地理位置,或在进入会话后每5秒上报一次地理位置,公众号可以在公众平台网站中修改以上设置。上报地理位置时,微信会将上报地理位置事件推送到开发者填写的URL。 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,LOCATION Latitude 地理位置纬度 Longitude 地理位置经度 Precision 地理位置精度 使用网页调试工具调试该接口 自定义菜单事件用户点击自定义菜单后,微信会把点击事件推送给开发者,请注意,点击菜单弹出子菜单,不会产生上报。 点击菜单拉取消息时的事件推送 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,CLICK EventKey 事件KEY值,与自定义菜单接口中KEY值对应  点击菜单跳转链接时的事件推送 推送<参数说明: 参数 描述 ToUserName 开发者微信号 FromUserName 发送方帐号(一个OpenID) CreateTime 消息创建时间 (整型) MsgType 消息类型,event Event 事件类型,VIEW EventKey 事件KEY值,设置的跳转URL 

View Code

 

详细可以参照   官网

 

 事件基类封装

 

package com.souvc.weixin.message.event;/*** 类名: BaseEvent </br>* 描述: 事件基类</br>* 开发人员: souvc</br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class BaseEvent {  // 开发者微信号  private String ToUserName;  // 发送方帐号(一个OpenID)  private String FromUserName;  // 消息创建时间 (整型)  private long CreateTime;  // 消息类型  private String MsgType;  // 事件类型  private String Event;  public String getToUserName() {    return ToUserName;  }  public void setToUserName(String toUserName) {    ToUserName = toUserName;  }  public String getFromUserName() {    return FromUserName;  }  public void setFromUserName(String fromUserName) {    FromUserName = fromUserName;  }  public long getCreateTime() {    return CreateTime;  }  public void setCreateTime(long createTime) {    CreateTime = createTime;  }  public String getMsgType() {    return MsgType;  }  public void setMsgType(String msgType) {    MsgType = msgType;  }  public String getEvent() {    return Event;  }  public void setEvent(String event) {    Event = event;  }}

 

 

 (1)关注/取消关注事件

 

package com.souvc.weixin.message.event;/*** 类名: SubscribeEvent </br>* 描述: 关注/取消关注事件 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class SubscribeEvent extends BaseEvent {}

 

 

(2)扫描带参数二维码事件

 

package com.souvc.weixin.message.event;/*** 类名: QRCodeEvent </br>* 描述: 扫描带参数二维码事件 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class QRCodeEvent extends BaseEvent {  // 事件KEY值  private String EventKey;  // 用于换取二维码图片  private String Ticket;  public String getEventKey() {    return EventKey;  }  public void setEventKey(String eventKey) {    EventKey = eventKey;  }  public String getTicket() {    return Ticket;  }  public void setTicket(String ticket) {    Ticket = ticket;  }}

 

 

(3)上报地理位置事件

 

package com.souvc.weixin.message.event;/*** 类名: LocationEvent </br>* 描述: 上报地理位置事件 </br>* 开发人员: liuhf </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class LocationEvent extends BaseEvent {  // 地理位置纬度  private String Latitude;  // 地理位置经度  private String Longitude;  // 地理位置精度  private String Precision;  public String getLatitude() {    return Latitude;  }  public void setLatitude(String latitude) {    Latitude = latitude;  }  public String getLongitude() {    return Longitude;  }  public void setLongitude(String longitude) {    Longitude = longitude;  }  public String getPrecision() {    return Precision;  }  public void setPrecision(String precision) {    Precision = precision;  }}

 

 

(4)自定义菜单事件

 

 

package com.souvc.weixin.message.event;/*** 类名: MenuEvent </br>* 描述: 自定义菜单事件 </br>* 开发人员: liuhf </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class MenuEvent extends BaseEvent {  // 事件KEY值,与自定义菜单接口中KEY值对应  private String EventKey;  public String getEventKey() {    return EventKey;  }  public void setEventKey(String eventKey) {    EventKey = eventKey;  }}

 

 

三、封装响应消息

 

     当用户发送消息给公众号时(或某些特定的用户操作引发的事件推送时),会产生一个POST请求,开发者可以在响应包(Get)中返回特定

    各消息类型需要的

    

 回复文本消息<参数   是否必须   描述ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间 (整型)MsgType   是   textContent   是   回复的消息内容(换行:在content中能够换行,微信客户端就支持换行显示)回复图片消息<参数   是否必须   说明ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间 (整型)MsgType   是   imageMediaId   是   通过素材管理接口上传多媒体文件,得到的id。回复语音消息<参数   是否必须   说明ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间戳 (整型)MsgType   是   语音,voiceMediaId   是   通过素材管理接口上传多媒体文件,得到的id回复视频消息<参数   是否必须   说明ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间 (整型)MsgType   是   videoMediaId   是   通过素材管理接口上传多媒体文件,得到的idTitle   否   视频消息的标题Description   否   视频消息的描述回复音乐消息<参数   是否必须   说明ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间 (整型)MsgType   是   musicTitle   否   音乐标题Description   否   音乐描述MusicURL   否   音乐链接HQMusicUrl   否   高质量音乐链接,WIFI环境优先使用该链接播放音乐ThumbMediaId   否   缩略图的媒体id,通过素材管理接口上传多媒体文件,得到的id回复图文消息< 参数   是否必须   说明ToUserName   是   接收方帐号(收到的OpenID)FromUserName   是   开发者微信号CreateTime   是   消息创建时间 (整型)MsgType   是   newsArticleCount   是   图文消息个数,限制为10条以内Articles   是   多条图文消息信息,默认第一个item为大图,注意,如果图文数超过10,则将会无响应Title   否   图文消息标题Description   否   图文消息描述PicUrl   否   图片链接,支持JPG、PNG格式,较好的效果为大图360*200,小图200*200Url   否   点击图文消息跳转链接 

View Code

 

详细可以查看  官网

 

同样,把消息回复中定义的所有消息都有的字段提取出来,封装成一个基类,

这些公有的字段包括:

ToUserName(接收方帐号,用户的OPEN_ID);

FromUserName(开发者的微信号);

CreateTime(消 息的创建时间);

MsgType(消息类型);

FuncFlag(消息的星标标识)。

 

响应消息的基类BaseMessage:

 

 

package com.souvc.weixin.message.resp;/*** 类名: BaseMessage </br>* 描述: 消息基类(公众帐号 -> 普通用户) </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class BaseMessage {  // 接收方帐号(收到的OpenID)  private String ToUserName;  // 开发者微信号  private String FromUserName;  // 消息创建时间 (整型)  private long CreateTime;  // 消息类型  private String MsgType;  public String getToUserName() {    return ToUserName;  }  public void setToUserName(String toUserName) {    ToUserName = toUserName;  }  public String getFromUserName() {    return FromUserName;  }  public void setFromUserName(String fromUserName) {    FromUserName = fromUserName;  }  public long getCreateTime() {    return CreateTime;  }  public void setCreateTime(long createTime) {    CreateTime = createTime;  }  public String getMsgType() {    return MsgType;  }  public void setMsgType(String msgType) {    MsgType = msgType;  }}

 

 

(1)回复文本消息

 

package com.souvc.weixin.message.resp;/*** 类名: TextMessage </br>* 描述: 文本消息 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class TextMessage extends BaseMessage {  // 回复的消息内容  private String Content;  public String getContent() {    return Content;  }  public void setContent(String content) {    Content = content;  }}

 

 

(2)回复图片消息

 

package com.souvc.weixin.message.resp;/*** 类名: Image </br>* 描述: 图片 </br>* 开发人员:souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class Image {    private String MediaId;  public String getMediaId() {    return MediaId;  }  public void setMediaId(String mediaId) {    MediaId = mediaId;  }}

 

package com.souvc.weixin.message.resp;/*** 类名: ImageMessage </br>* 描述: 图片消息</br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class ImageMessage extends BaseMessage {    private Image Image;  public Image getImage() {    return Image;  }  public void setImage(Image image) {    Image = image;  }}

 

 

(3)回复语音消息

 

 

package com.souvc.weixin.message.resp;/*** 类名: Voice </br>* 描述: 语音model </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class Voice {  // 媒体文件id  private String MediaId;  public String getMediaId() {    return MediaId;  }  public void setMediaId(String mediaId) {    MediaId = mediaId;  }}

 

package com.souvc.weixin.message.resp;/*** 类名: VoiceMessage </br>* 描述: 语音消息</br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class VoiceMessage extends BaseMessage {  // 语音  private Voice Voice;  public Voice getVoice() {    return Voice;  }  public void setVoice(Voice voice) {    Voice = voice;  }}

 

 

(4)回复视频消息

 

package com.souvc.weixin.message.resp;/*** 类名: Video </br>* 描述: 视频model </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class Video {  // 媒体文件id  private String MediaId;  // 缩略图的媒体id  private String ThumbMediaId;  public String getMediaId() {    return MediaId;  }  public void setMediaId(String mediaId) {    MediaId = mediaId;  }  public String getThumbMediaId() {    return ThumbMediaId;  }  public void setThumbMediaId(String thumbMediaId) {    ThumbMediaId = thumbMediaId;  }}

 

package com.souvc.weixin.message.resp;/*** 类名: VideoMessage </br>* 描述: 视频消息 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class VideoMessage extends BaseMessage {  // 视频  private Video Video;  public Video getVideo() {    return Video;  }  public void setVideo(Video video) {    Video = video;  }}

 

 

(5)回复音乐消息

 

package com.souvc.weixin.message.resp;/*** 类名: Music </br>* 描述: 音乐model </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class Music {  // 音乐标题  private String Title;  // 音乐描述  private String Description;  // 音乐链接  private String MusicUrl;  // 高质量音乐链接,WIFI环境优先使用该链接播放音乐  private String HQMusicUrl;  // 缩略图的媒体id,通过上传多媒体文件得到的id  private String ThumbMediaId;  public String getTitle() {    return Title;  }  public void setTitle(String title) {    Title = title;  }  public String getDescription() {    return Description;  }  public void setDescription(String description) {    Description = description;  }  public String getMusicUrl() {    return MusicUrl;  }  public void setMusicUrl(String musicUrl) {    MusicUrl = musicUrl;  }  public String getHQMusicUrl() {    return HQMusicUrl;  }  public void setHQMusicUrl(String musicUrl) {    HQMusicUrl = musicUrl;  }  public String getThumbMediaId() {    return ThumbMediaId;  }  public void setThumbMediaId(String thumbMediaId) {    ThumbMediaId = thumbMediaId;  }}

 

package com.souvc.weixin.message.resp;/*** 类名: MusicMessage </br>* 描述: 音乐消息 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class MusicMessage extends BaseMessage {  // 音乐  private Music Music;  public Music getMusic() {    return Music;  }  public void setMusic(Music music) {    Music = music;  }}

 

(6) 回复图文消息

package com.souvc.weixin.message.resp;/*** 类名: Article </br>* 描述: 图文model </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class Article {  // 图文消息名称  private String Title;  // 图文消息描述  private String Description;  // 图片链接,支持JPG、PNG格式,较好的效果为大图640*320,小图80*80  private String PicUrl;  // 点击图文消息跳转链接  private String Url;  public String getTitle() {    return Title;  }  public void setTitle(String title) {    Title = title;  }  public String getDescription() {    return null == Description ? "" : Description;  }  public void setDescription(String description) {    Description = description;  }  public String getPicUrl() {    return null == PicUrl ? "" : PicUrl;  }  public void setPicUrl(String picUrl) {    PicUrl = picUrl;  }  public String getUrl() {    return null == Url ? "" : Url;  }  public void setUrl(String url) {    Url = url;  }}

 

package com.souvc.weixin.message.resp;import java.util.List;/*** 类名: NewsMessage </br>* 描述: 文本消息 </br>* 开发人员: souvc </br>* 创建时间: 2015-9-30 </br>* 发布版本:V1.0 </br> */public class NewsMessage extends BaseMessage {  // 图文消息个数,限制为10条以内  private int ArticleCount;  // 多条图文消息信息,默认第一个item为大图  private List<Article> Articles;  public int getArticleCount() {    return ArticleCount;  }  public void setArticleCount(int articleCount) {    ArticleCount = articleCount;  }  public List<Article> getArticles() {    return Articles;  }  public void setArticles(List<Article> articles) {    Articles = articles;  }}

 

封装结束。