作者:王先荣
    本文介绍微信公众号中的模板消息,包括以下内容:(1)TemplateMessage类简介;(2)设置所属行业;(3)获得模板id;(4)发送模板消息;(5)接收推送模板消息发送结果事件。
    本文演示地址:http://xrwang.net/Example/TemplateMessage.aspx
    本文源代码地址:
    http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount/tree/master/PublicAccount/TemplateMessage
    http://git.oschina.net/xrwang2/xrwang.weixin.PublicAccount/blob/master/xrwang.net/Example/TemplateMessage.aspx.cs

1 TemplateMessage类简介
    TemplateMessage静态类封装了跟模板消息相关的方法,见下表:

方法名 功能
SetIndustry 设置行业
GetId 获取模板id
Send 发送模板消息

2 设置所属行业

TemplateMessage类的SetIndustry方法用于设置公众号所属的行业,该方法的定义如下:

        /// <summary>
/// 设置行业
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="code1">行业代码1</param>
/// <param name="code2">行业代码2</param>
/// <returns>返回设置是否成功</returns>
public static ErrorMessage SetIndustry(string userName, string code1, string code2) //或者 /// <summary>
/// 设置行业
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="industry1">行业1</param>
/// <param name="industry2">行业2</param>
/// <returns>返回设置是否成功</returns>
public static ErrorMessage SetIndustry(string userName, Industry industry1, Industry industry2)

其中,Industry为行业类,类中的静态成员包含了已知的所有行业,例如:Industry.OnlineGame代表了网络游戏这一行业;Industry类有三个属性,分别为:Code——行业代码,Name——行业名称,PrimaryIndustry——主行业。

设置所属行业的示例:

    /// <summary>
/// 设置所属行业
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSetIndustry_Click(object sender, EventArgs e)
{
string userName = lbPublicAccount.SelectedValue;
string industryCode1 = "", industryCode2 = "";
int count = ;
foreach (ListItem item in cblIndustry.Items)
{
if (item.Selected)
{
count++;
if (count == )
industryCode1 = item.Value;
else if (count == )
{
industryCode2 = item.Value;
break;
}
}
}
if (count != )
ltrMessage.Text = "请选择两个行业。";
else
{
ErrorMessage errorMessage = TemplateMessage.SetIndustry(userName, industryCode1, industryCode2);
ltrMessage.Text = string.Format("设置所属行业{0}。{1}",
errorMessage.IsSuccess ? "成功" : "失败",
errorMessage.IsSuccess ? "" : errorMessage.ToString());
}
}

设置所属行业示例

3 获得模板id

TemplateMessage类的GetId方法用于获取模板id,该方法定义如下:

        /// <summary>
/// 获取模板ID
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="shortTemplateId">模板库中模板的编号,有“TM**”和“OPENTMTM**”等形式</param>
/// <param name="errorMessage">返回获取是否成功</param>
/// <returns>返回模板ID;如果获取失败,返回空字符串。</returns>
public static string GetId(string userName, string shortTemplateId, out ErrorMessage errorMessage)

注意:(1)如果尚未添加模板,该方法会先添加模板,然后返回模板id;(2)如果已经添加了模板,再次调用该方法,会返回一个新的不同于上次获取到的模板id。

获得模板id的示例:

    /// <summary>
/// 添加并模板id
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnGetTemplateId_Click(object sender, EventArgs e)
{
string userName = lbPublicAccount.SelectedValue;
ErrorMessage errorMessage;
string templateId = TemplateMessage.GetId(userName, txtTemplateIdShort.Text, out errorMessage);
if (errorMessage.IsSuccess)
ltrMessage.Text = string.Format("添加并获取模板id成功。模板id:{0}", templateId);
else
ltrMessage.Text = string.Format("添加并获取模板id失败。{0}", errorMessage.ToString());
}

获得模板id示例

4 发送模板消息
    TemplateMessage类的Send方法用于发送模板消息,该方法定义如下:

        /// <summary>
/// 发送模板消息
/// </summary>
/// <param name="userName">公众号</param>
/// <param name="touser">接收消息的账号</param>
/// <param name="templateId">模板id</param>
/// <param name="detailUrl">详情地址</param>
/// <param name="topColor">顶端颜色</param>
/// <param name="data">数据</param>
/// <param name="errorMessage">返回发送是否成功</param>
/// <returns>返回消息id;如果发送失败,返回-1。</returns>
public static long Send(string userName, string touser, string templateId, string detailUrl, Color topColor,
Tuple<string, string, Color>[] data, out ErrorMessage errorMessage)

其中,data参数为Tuple类型,包含模板所用的数据,data.Item1为数据键,data.Item2为数据值,data.Item3为显示数据的颜色。

发送模板消息的示例:

    /// <summary>
/// 发送模板消息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void btnSend_Click(object sender, EventArgs e)
{
if (rblUser.SelectedIndex >= )
{
string userName = lbPublicAccount.SelectedValue;
string openId = rblUser.SelectedValue;
string templateId = "z8zHvTm2gpU0gZUBwA0dXibMO_VYy6iwJYgtW6qeyPg";
string title = txtTitle.Text;
string name = txtUserName.Text;
string time = DateTime.Now.ToString();
Tuple<string, string, Color>[] data = new Tuple<string, string, Color>[]{
new Tuple<string,string,Color>("title",title,Color.Blue),
new Tuple<string,string,Color>("username",name,Color.Green),
new Tuple<string,string,Color>("time",time,Color.Red)
};
ErrorMessage errorMessage;
long msgId = TemplateMessage.Send(userName, rblUser.SelectedValue, templateId, "", Color.Black, data, out errorMessage);
if (errorMessage.IsSuccess)
ltrMessage.Text = string.Format("发送模板消息成功。消息id:{0}", msgId);
else
ltrMessage.Text = string.Format("发送模板消息失败。{0}", errorMessage);
}
}

发送模板消息示例

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

        /// <summary>
/// 获取消息id
/// </summary>
public long MsgID { get; private set; }
/// <summary>
/// 获取群发消息的结果
/// </summary>
public string Status { get; private set; } /// <summary>
/// 获取消息是否群发成功
/// </summary>
public TemplateMessageSendStatusEnum SendStatus
{
get
{
TemplateMessageSendStatusEnum status;
if (Status == sendFailedUserBlock)
status = TemplateMessageSendStatusEnum.UserBlock;
else if (Status == sendFailedSystemFailed)
status = TemplateMessageSendStatusEnum.SystemFailed;
else
status = TemplateMessageSendStatusEnum.Success;
return status;
}
}

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

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

  1. php之微信公众号发送模板消息

    讲一下开发项目中微信公众号发送模板消息的实现过程(我用的还是Thinkphp5.0). 先看一下效果,如图: 就是类似于这样的,下面讲一下实现过程: 第一步:微信公众号申请模板消息权限: 立即申请: ...

  2. .net微信公众号开发——群发消息

    作者:王先荣    本文将介绍微信公众号开发中用于群发消息的类MassMessage,包括:(1)MassMessage类:(2)群发:(3)删除:(4)预览:(5)查询发送状态:(6)接收推送群发结 ...

  3. php之微信公众号发送模板消息参观模仿

    上篇文章中鞋到了公众号发送末班消息,他是最后调用两个方法,本文章简化一下 将下面的php方法放到一个可以引入的公共类中即可 构建模板消息: 我把需要用到的模板消息 都写成一个个方法,放在公共类文件中了 ...

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. [UE4]武器碰撞

    实现武器战斗伤害系统,击中时如何发出碰撞事件产生伤害,目前探索的有通过物理碰撞和LineTrace两种方法. 物理碰撞通过Overlap事件的方法,优点是易于实现,缺点是无法具体到碰撞骨骼位置,低帧数 ...

  2. linux知识点总结与随笔(关注linux爱好者公众号的一些笔记)

    sysdig工具,可以有strace ,tcpdump,lsof的功能. 前台任务与后台任务,知识点:test.sh &,Ctrl+z,bg,shopt grep |huponexit(sho ...

  3. p7 struct and union

    struct  StudentRec           //①声明结构体类型StudentRec{        char StuNum[20];        //②定义结构体的成员变量      ...

  4. 用dom4j解析xml 报java.lang.NoClassDefFoundError:org/jaxen/JaxenException

    转自:http://www.myexception.cn/java%20exception/95.html 源码如下: import java.io.File; import java.util.Li ...

  5. mysql pid文件

    mysql pid文件记录的是当前mysqld进程的pid. 通过Mysqld_safe启动mysql时,mysqld_safe会检查pid文件,未指定PID文件时,pid文件默认名为$DATADIR ...

  6. .NET跨平台:在mac命令行下用vim手写ASP.NET 5 MVC程序

    昨天在 Mac 上手写了一个最简单的 ASP.NET 5 程序,直接在 Startup.cs 中通过 Response.WriteAsync() 输出响应内容,详见 .NET跨平台:在Mac上跟着错误 ...

  7. Android开发学习总结——Android开发的一些相关概念

    一.什么是3G.4G 1995年问世的第一代模拟制式手机(1G)只能进行语音通话. 1996到1997年出现的第二代GSM.CDMA等数字制式手机(2G)便增加了接收数据的功能 Ÿ 3G指的是第三代移 ...

  8. python 守护进程 daemon

    python 守护进程 daemon # -*-coding:utf-8-*- import sys, os '''将当前进程fork为一个守护进程 注意:如果你的守护进程是由inetd启动的,不要这 ...

  9. C#与数据库访问技术总结(五)之Command对象的常用方法

    Command对象的常用方法 说明:上篇总结了Command对象的几个数据成员,这节总结Command对象的常用方法. 同样,在不同的数据提供者的内部,Command对象的名称是不同的,在SQL Se ...

  10. 【Linux高级驱动】LCD logo

    1.将LOGO图片的大小调整到合适尺寸(480x272) 2. 使用GIMP2生成符合Linux要求的PPM图片文件 启动GIMP2打开通过ACDSEE调整的图片-->    通过菜单 图像模式 ...