在V2版本发布的博文中,已经介绍了大多数Api的用法,同时也收到了很多意见,其中发布了几个修正版本,修改了几个bug,在此感谢大家的使用,有了大家的支持,相信快速开发框架会越来越好,也会越来越完善的。

如果您是第一次看到此框架,可以先从以下链接了解下:

一、对微信公众平台开发的消息处理
   二、快速开发微信公众平台框架---简介
   三、建立微信公众平台测试账号
   四、体验微信公众平台快速开发框架
   五、利用快速开发框架,快速搭建微信浏览博客园首页文章
   六、微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github

版本说明

此版本关键是增加了“发送客服消息”接口,之前大意了,忘记写了,幸亏@我想我是风的提醒。

目前此项目属于开源项目,所有代码都在github中,您也可以通过NuGet获取

PM> Install-Package JCSoft.WX.Framework

微信文档中,对于“发送客服消息”有一定限制,必须关注者发送过来消息,包括关注、自定义菜单等事件,我们可以在48小时内通过Post一个Json数据包,发送6种形式的消息。

我用以下名称,对应这6种消息方式:

1、文本消息:MessageCustomSendTextRequest

2、图片消息:MessageCustomSendImageRequest

3、语音消息:MessageCustomSendVoiceRequest

4、视频消息:MessageCustomSendVideoRequest

5、音乐消息:MessageCustomSendMusicRequest

6、图文消息:MessageCustomSendNewsRequest

以上几个Request继承自MessageCustomSendRequest,对应了统一MessageCustomSendResponse。

使用方法

看过之前系列的,应该知道如何使用此Api,这里简单说下几个消息类型的构建:

文本消息:

var textRequest = new MessageCustomSendTextRequest
{
ToUser = "james",
Text = new WX.Model.TextMessage
{
Content = "test content"
}
};

图片消息:

        var imageRequest = new MessageCustomSendImageRequest
{
ToUser = "james",
Image = new ImageMessage
{
MediaId = "image_media_id"
}
};

语音消息:

        var voiceRequest = new MessageCustomSendVoiceRequest
{
ToUser = "james",
Voice = new VoiceMessage
{
MediaId = "voice_media_id"
}
};

视频消息:

        var videoRequest = new MessageCustomSendVideoRequest
{
ToUser = "james",
Video = new VideoMessage
{
MediaId = "video_media_id",
Title = "video test title"
}
};

音乐消息:

var musicRequest = new MessageCustomSendMusicRequest
{
ToUser = "james",
Music = new MusicMessage
{
Title = "test music title",
HQMusicUrl = "hqmusicurl",
MusicURL = "musicurl",
ThumbMediaId = "media_id"
}
};

图文消息:

        var newsRequest = new MessageCustomSendNewsRequest
{
ToUser = "james",
News = new NewsMessage
{
Articles = new List<NewsArticleMessage>
{
new NewsArticleMessage{
Title = "Happy Day",
Description = "Is Really A Happy Day",
Url = "url1",
PicUrl = "picurl1"
},
new NewsArticleMessage {
Title = "Happy Day",
Description = "Is Really A Happy Day",
Url = "url2",
PicUrl = "picurl2"
}
}
}
};

以上实例中,ToUser为用户的OpenId

构建了Request后,只要使用IApiClient.Execute(request)即可得到微信服务端给我们的反馈。

实战测试

测试中,我只测试了文本消息和图文消息,通过执行后,结果如下图所示:

其余几个至测试了输出的json数据包,并未实战测试,大家也可以帮我测试下。

写在最后

这次非常感谢几位朋友的测试,对我完善框架提供了很大的帮助,因为精力有限,有时候难免会出现这样或者那样的错误。现在体会到开源的好处,不仅可以完善自己的项目,还能提高自己的水平,也希望大家也进入开源的大军来。

这1个月,在万网购买了主机和域名,现在大家可以通过浏览以下网址了解微信快速开发框架:

http://www.wxquickframework.com

微信快速开发框架(七)--发送客服信息,版本更新至V2.2 代码已更新至github的更多相关文章

  1. 微信快速开发框架(八)-- V2.3--增加语音识别及网页获取用户信息,代码已更新至Github

    不知不觉,版本以每周更新一次的脚步进行着,接下来应该是重构我的代码及框架的结构,有朋友反应代码有点乱,确实如此,当时写的时候只是按照订阅号来写的,后来才慢慢增加到支持API接口.目前还在开发第三方微信 ...

  2. 微信快速开发框架(九)-- V3.0发布,代码已更新至Github 新增微店功能

    版本内容 1.修正了缺少对Event.View的支持 2.增加了用户UnionID 3.新增微信小店功能 4.多客服功能 5.单元测试 什么是UnionID 我们知道,每个用户针对一个微信公众账号都有 ...

  3. java微信开发(wechat4j)——发送客服消息

    微信支持主动发送客服消息.如果你要实现此功能,需要使用CustomerMsg类. 获得access_token access_token请求之后有一个过期时间,微信平台建议你使用一个中控服务器来定时刷 ...

  4. 微信公众号发送客服消息提示errcode":45015,"errmsg":"response out of time limit or subscription is canceled hint:解决办法【已解决】

    微信公众号发送客服消息提示errcode":45015,"errmsg":"response out of time limit or subscription ...

  5. 微信快速开发框架(六)-- 微信快速开发框架(WXPP QuickFramework)V2.0版本上线--源码已更新至github

    4月28日,已增加多媒体上传及下载API,对应MediaUploadRequest和MediaGetRequest ------------------------------------------ ...

  6. php 微信客服信息推送失败 微信重复推送客服消息 40001 45047

    /*** * 微信客服发送信息 * 微信客服信息推送失败 微信重复推送客服消息 40001 45047 * 递归提交到微信 直到提交成功 * @param $openid * @param int $ ...

  7. 微信小程序之快速接入七牛云

    小程序为什么要接入云? 目前,开发者在开发小程序过程中,主要遇到以下几个问题: 小程序发布大小超限 微信官方限制小程序的发布代码不能超过 1MB,而在实际开发过程中,一般的小程序难免会有图片等富媒体文 ...

  8. 如何让微信小程序快速接入七牛云

    如果你确定用七牛运行小程序的话,给大家分享一个九折优惠码:61d1fd4d1 月 9 日 微信小程序正式发布,小程序终于揭开了它神秘的面纱,开发者对小程序的追捧更是热度不减.从小程序的热门应用场景来看 ...

  9. 微信公众平台快速开发框架 For Core 2.0 beta –JCSoft.WX.Core 5.2.0 beta发布

    写在前面 最近比较忙,都没有好好维护博客,今天拿个半成品来交代吧. 记不清上次关于微信公众号快速开发框架(简称JCWX)的更新是什么时候了,自从更新到支持.Net Framework 4.0以后基本上 ...

随机推荐

  1. 迷你版jQuery——zepto核心源码分析

    前言 zepto号称迷你版jQuery,并且成为移动端dom操作库的首选 事实上zepto很多时候只是借用了jQuery的名气,保持了与其基本一致的API,其内部实现早已面目全非! 艾伦分析了jQue ...

  2. js的url解析函数封装

    在实际开发中,有些通过get方式与后台交换数据的时候,需要用到的数据在url中,因此就需要我们来获取到url中有用的信息,下面封装的函数已经可以将url解析的很彻底了,可以拿来直接用的: functi ...

  3. DevExpress TreeList使用心得

    来自:http://www.cnblogs.com/sndnnlfhvk/archive/2011/05/15/2046920.html 最近做项目新增光纤线路清查功能模块,思路和算法已经想好了,些代 ...

  4. shiro 实现单用户登录,一个用户同一时刻只能在一个地方登录

    我这里 shiro 并没有集成 springMVC,直接使用 ini 配置文件. shiro.ini [main] # Objects and their properties are defined ...

  5. 每个程序员都会的 35 个 jQuery 小技巧

    1. 禁止右键点击 $(document).ready(function(){ $(document).bind("contextmenu",function(e){ return ...

  6. Android 手机卫士--对话初次设置密码验证过程

    本文实现设置密码对话框的逻辑判断 本文地址:http://www.cnblogs.com/wuyudong/p/5940551.html,转载请注明出处. 首先添加上图按钮的监听事件代码 /** * ...

  7. iOS切图文件的命名规范

    万能公式:

  8. LVS+Keepalived+Squid+Nginx+MySQL主从高性能集群架构部署方案

    方案一,在tomcat的workers.properties里面配置相关条件 worker.tomcat.lbfactor= worker.tomcat.cachesize= worker.tomca ...

  9. NSError

    -(NSString * )backErrorString{ //    self.code; //http://blog.csdn.net/linkai5696/article/details/59 ...

  10. 通过Ajax使用FormData对象无刷新上传文件

    写在前面:本文说的这个方案有浏览器兼容性问题:所有主流浏览器的较新版本已经支持这个对象了,比如Chrome 7+.Firefox 4+.IE 10+.Opera 12+.Safari 5+,对兼容性比 ...