作者:王先荣
    本文将介绍微信公众号开发中用于群发消息的类MassMessage,包括:(1)MassMessage类;(2)群发;(3)删除;(4)预览;(5)查询发送状态;(6)接收推送群发结果事件。
    源代码地址:http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount/tree/master/PublicAccount/MassMessage
    演示地址:http://www.xrwang.net/Example/MassMessage.aspx

1 MassMessage类
    MassMessage静态类封装了群发消息相关的方法,如下表:

作用 方法名
群发 Send
删除 Delete
预览 Preview
查询发送状态 GetStatus

2 群发
    公众号可以按用户分组群发消息,也可以按用户的OpenId列表来群发群发消息。
2.1 按用户分组群发消息
    方法定义如下:

/// <summary>
/// 根据分组群发消息
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="isToAll">是否群发给所有用户</param>
/// <param name="groupId">如果群发给所有用户,忽略该参数;否则群发给该组中的用户</param>
/// <param name="messageType">群发消息类型</param>
/// <param name="mediaIdOrContent">多媒体id或者文本内容</param>
/// <param name="errorMessage">返回发送是否成功</param>
/// <returns>如果发送成功,返回消息ID;否则,返回-1。</returns>
public static long Send(string userName, bool isToAll, string groupId, MassMessageTypeEnum messageType, string mediaIdOrContent, out ErrorMessage errorMessage)

使用示例如下:

    /// <summary>
/// 按分组群发消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSendToGroup_Click(object sender, EventArgs e)
{
if (rblGroup.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
ErrorMessage errorMessage;
bool isToAll = string.IsNullOrWhiteSpace(rblGroup.SelectedValue);
string groupId = isToAll ? "" : rblGroup.SelectedValue;
string content = txtContent.Text;
long msgId = MassMessage.Send(userName, isToAll, groupId, MassMessageTypeEnum.text, content, out errorMessage);
if (errorMessage.IsSuccess)
{
ltrMessage.Text = "群发消息成功。";
rblMassMessage.Items.Add(new ListItem(string.Format("id:{0},text:{1}", msgId, content), msgId.ToString()));
}
else
ltrMessage.Text = string.Format("群发消息失败。{0}", errorMessage);
}
}

按用户分组群发消息示例

2.2 按OpenId列表群发

方法定义如下:

/// <summary>
/// 根据OpenId列表群发消息
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="tousers">OpenId列表</param>
/// <param name="messageType">群发消息类型</param>
/// <param name="mediaIdOrContent">多媒体id或者文本内容</param>
/// <param name="errorMessage">返回发送是否成功</param>
/// <returns>如果发送成功,返回消息ID;否则,返回-1。</returns>
public static long Send(string userName, IEnumerable<string> tousers, MassMessageTypeEnum messageType, string mediaIdOrContent, out ErrorMessage errorMessage)

使用示例如下:

    /// <summary>
/// 按用户群发消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSendToUsers_Click(object sender, EventArgs e)
{
if (cblUser.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
ErrorMessage errorMessage;
List<string> openIds = new List<string>();
foreach (ListItem item in cblUser.Items)
{
if (item.Selected)
openIds.Add(item.Value);
}
string content = txtContent.Text;
long msgId = MassMessage.Send(userName, openIds, MassMessageTypeEnum.text, content, out errorMessage);
if (errorMessage.IsSuccess)
{
ltrMessage.Text = "群发消息成功。";
rblMassMessage.Items.Add(new ListItem(string.Format("id:{0},text:{1}", msgId, content), msgId.ToString()));
}
else
ltrMessage.Text = string.Format("群发消息失败。{0}", errorMessage);
}
}

按用户OpenId列表群发消息示例

3 删除群发
    删除已群发消息的方法定义如下:

/// <summary>
/// 删除群发消息。
/// 注:只能删除图文消息和视频消息。
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="messageId">消息id</param>
/// <returns>返回删除是否成功</returns>
public static ErrorMessage Delete(string userName, long messageId)

使用示例如下:

    /// <summary>
/// 删除群发消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnDelete_Click(object sender, EventArgs e)
{
if (rblMassMessage.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
long msgId = long.Parse(rblMassMessage.SelectedValue);
ErrorMessage errorMessage = MassMessage.Delete(userName, msgId);
if (errorMessage.IsSuccess)
{
ltrMessage.Text = "删除消息成功。";
rblMassMessage.Items.Remove(rblMassMessage.SelectedItem);
}
else
ltrMessage.Text = string.Format("删除消息失败。{0}", errorMessage);
}
}

删除群发的示例

4 预览群发
    预览群发消息的方法定义如下:

/// <summary>
/// 预览群发消息
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="touser">OpenId</param>
/// <param name="messageType">群发消息类型</param>
/// <param name="mediaIdOrContent">多媒体id或者文本内容</param>
/// <param name="errorMessage">返回发送是否成功</param>
/// <returns>如果发送成功,返回消息ID;否则,返回-1。</returns>
public static long Preview(string userName, string touser, MassMessageTypeEnum messageType, string mediaIdOrContent, out ErrorMessage errorMessage)

使用示例如下:

    /// <summary>
/// 预览群发消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnPreview_Click(object sender, EventArgs e)
{
if (cblUser.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
ErrorMessage errorMessage;
string openId = cblUser.SelectedValue;
string content = txtContent.Text;
long msgId = MassMessage.Preview(userName, openId, MassMessageTypeEnum.text, content, out errorMessage);
if (errorMessage.IsSuccess)
{
ltrMessage.Text = "预览消息成功。";
rblMassMessage.Items.Add(new ListItem(string.Format("id:{0},text:{1}", msgId, content), msgId.ToString()));
}
else
ltrMessage.Text = string.Format("预览消息失败。{0}", errorMessage);
}
}

预览群发的示例

5 查询群发消息发送状态
    查询群发消息发送状态的方法定义如下:

/// <summary>
/// 查询群发消息的发送状态
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="messageId">消息id</param>
/// <param name="errorMessage">返回查询是否成功</param>
/// <returns>返回消息是否发送成功</returns>
public static bool GetStatus(string userName, long messageId, out ErrorMessage errorMessage)

使用示例如下:

    /// <summary>
/// 查询群发消息状态
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnGetStatus_Click(object sender, EventArgs e)
{
if (rblMassMessage.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
ErrorMessage errorMessage;
long msgId = long.Parse(rblMassMessage.SelectedValue);
bool success = MassMessage.GetStatus(userName, msgId, out errorMessage);
if (errorMessage.IsSuccess)
ltrMessage.Text = string.Format("消息群发{0}。", success ? "成功" : "失败");
else
ltrMessage.Text = string.Format("获取消息群发状态失败。{0}", errorMessage);
}
}

查询群发发送状态的示例

6 接收推送群发结果事件
    群发消息之后,微信服务器会推送群发的结果到公众号的指定URL上,公众号服务器会接收到一条RequestMassSendJobFinishMessage类型的请求消息。
    RequestMassSendJobFinishMessage类有以下只读属性:

        /// <summary>
/// 获取消息id
/// </summary>
public long MsgID { get; private set; }
/// <summary>
/// 获取群发消息的结果
/// </summary>
public string Status { get; private set; }
/// <summary>
/// 获取用户总数
/// </summary>
public int TotalCount { get; private set; }
/// <summary>
/// 获取过滤后待发送的用户数
/// </summary>
public int FilterCount { get; private set; }
/// <summary>
/// 获取发送成功的用户数
/// </summary>
public int SentCount { get; private set; }
/// <summary>
/// 获取发送失败的用户数
/// </summary>
public int ErrorCount { get; private set; } /// <summary>
/// 获取消息是否群发成功
/// </summary>
public bool SendSuccess
{
get
{
return Status == sendSuccess;
}
}
/// <summary>
/// 获取发送失败的原因
/// </summary>
public string ErrorReason
{
get
{
string reason = string.Empty;
if (Status == sendSuccess)
reason = "发送成功";
else if (Status == sendFailed)
reason = "发送失败";
else if (errorDict.ContainsKey(Status))
reason = errorDict[Status];
return reason;
}
}

感谢您看完本文,希望对您有所帮助。

.net微信公众号开发——群发消息的更多相关文章

  1. .net微信公众号开发——模板消息

    作者:王先荣    本文介绍微信公众号中的模板消息,包括以下内容:(1)TemplateMessage类简介:(2)设置所属行业:(3)获得模板id:(4)发送模板消息:(5)接收推送模板消息发送结果 ...

  2. .net微信公众号开发——消息与事件

    作者:王先荣    本文介绍如何处理微信公众号开发中的消息与事件,包括:(1)消息(事件)概况:(2)验证消息的真实性:(3)解析消息:(4)被动回复消息:(5)发送其他消息.    开源项目地址:h ...

  3. 微信公众号开发之根据OpenID列表群发(十四)

    上一篇我们讲述了<微信公众号开发之根据标签进行群发(十二)>,这次我们讲解一下[根据OpenID列表群发] 根据OpenID列表群发[订阅号不可用,服务号认证后可用] 接口调用请求说明 h ...

  4. C#微信公众号开发系列教程三(消息体签名及加解密)

    http://www.cnblogs.com/zskbll/p/4139039.html C#微信公众号开发系列教程一(调试环境部署) C#微信公众号开发系列教程一(调试环境部署续:vs远程调试) C ...

  5. C#微信公众号开发系列教程五(接收事件推送与消息排重)

    微信公众号开发系列教程一(调试环境部署) 微信公众号开发系列教程一(调试环境部署续:vs远程调试) C#微信公众号开发系列教程二(新手接入指南) C#微信公众号开发系列教程三(消息体签名及加解密) C ...

  6. C#微信公众号开发系列教程四(接收普通消息)

    微信公众号开发系列教程一(调试环境部署) 微信公众号开发系列教程一(调试环境部署续:vs远程调试) C#微信公众号开发系列教程二(新手接入指南) C#微信公众号开发系列教程三(消息体签名及加解密) C ...

  7. 微信公众号开发C#系列-7、消息管理-接收事件推送

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

  8. PHP 微信公众号开发 - 消息推送

    项目微信公众号开发,需要做用户消息推送,记录下来以便日后使用 1,接上一篇文章,可以查看如何获取用户openid PHP 微信公众号开发 - 获取用户信息 2,添加模板消息 3,查看模板详情 根据模板 ...

  9. 转:C#微信公众号开发之接收事件推送与消息排重的方法

    本文实例讲述了C#微信公众号开发之接收事件推送与消息排重的方法.分享给大家供大家参考.具体分析如下: 微信服务器在5秒内收不到响应会断掉连接,并且重新发起请求,总共重试三次.这样的话,问题就来了.有这 ...

随机推荐

  1. 『TCP/IP详解——卷一:协议』读书笔记——03

    2013-08-17 17:31:49 1.7 分用 分用(Demultiplexing):这是一个过程——当目的主机收到一个以太网数据帧时,数据就开始从协议栈中由底向上升,同时去掉各层协议上的报文首 ...

  2. IOS封装一个微信聊天的输入工具

    1.实现微信的输入工具 实现了大部分功能,各模块实现的很清晰,有利于更好的二次开发(适合自己的需求),我自己总结出来的, 可以更快的让你实现输入工具,不需要扩展的也可以很方便的使用这个输入工具. 1) ...

  3. STL(1)

    这一篇因为游戏设计而写的,里面采用了STL,先借用一下,过段时间专项研究. 模板 模板就是一种通用化的类,同一种模板可以创建无数种具有共同特征的容器类型.首先需要指定基础类型,比如int ,char, ...

  4. 嵌入式linux自动登录

    最近又把同事的fl2440板子拿过来跑了起来,没有太大收获,就解决了一个自动登录的问题: ::respawn:/sbin/getty -L ttySAC0 115200 vt100 -n root - ...

  5. codeforces 425D

    题意:给定n<=100000个二维点,并且0<=x,y<=100000,求有多少个平行于坐标轴的正方形 思路:本来想hash的,但是感觉不好弄.. 后来感觉像是分块,最坏的情况就是那 ...

  6. 如何使用vs将现有的项目或者文件夹(尤其是多层目录的)添加到项目中

    困扰我这么久的问题,哎,真心弱爆了! 1.将现有项目或文件夹拷贝到指定目录下 2.解决方案右上有个显示所有文件的按钮 然后选中所有要添加的文件,右击 选择包含到项目中即可

  7. ASP.NET Web API从注释生成帮助文档

    默认情况下,ASP.NET Web API不从Controller的注释中生成帮助文档.如果要将注释作为Web API帮助文档的一部分,比如在帮助文档的Description栏目中显示方法注释中的su ...

  8. “System.Web.UI.WebControls.Literal”不允许使用子控件

    今天在写下面的代码时遭遇错误——“System.Web.UI.WebControls.Literal”不允许使用子控件('System.Web.UI.WebControls.Literal' does ...

  9. jenkins2 pipeline介绍

    文章来自:http://www.ciandcd.com 文中的代码来自可以从github下载: https://github.com/ciandcd   什么是jenkins2的pipeline?   ...

  10. C语言实现冒泡排序-整数排序

    我一直觉得排序算法挺重要的,但是却没有深入的去理解它: 没有深入理解就无法用代码将它实现: 在腾讯的在线模拟考试中就有一题问到冒泡排序: 我几乎是傻眼了!我知道这样的问题是最基础的: 无论过去怎样现在 ...