微信小程序-发送模板消息(C#)

步骤一:获取模板ID

有两个方法可以获取模版ID

  1. 通过模版消息管理接口获取模版ID
  2. 在微信公众平台手动配置获取模版ID

步骤二:页面的 

 组件,属性report-submittrue时,可以声明为需发模板消息,此时点击按钮提交表单可以获取formId,用于发送模板消息。或者当用户完成支付行为,可以获取prepay_id用于发送模板消息。

步骤三:调用接口下发模板消息

 

今天重要的说第三步怎么实现,前面的步骤比较简单就略过。

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

  1. 获取 access_token

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

后面会在发送模板消息的时候会用到access_token

  2. 发送模板消息

   接口地址:(ACCESS_TOKEN 需换成上文获取到的 access_token)

https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=ACCESS_TOKEN

注意说明:由于微信现在不让开发者直接在前端使用 https://api.weixin.qq.com 接口获取数据,所以下面的操作都必须由服务器后台来完成。

官方的POST参数:

微信小程序-发送模板消息(C#)_第1张图片
{
  "touser": "OPENID",  
  "template_id": "TEMPLATE_ID", 
  "page": "index",          
  "form_id": "FORMID",         
  "data": {
      "keyword1": {
          "value": "339208499", 
          "color": "#173177"
      }, 
      "keyword2": {
          "value": "2015年01月05日 12:30", 
          "color": "#173177"
      }, 
      "keyword3": {
          "value": "粤海喜来登酒店", 
          "color": "#173177"
      } , 
      "keyword4": {
          "value": "广州市天河区天河路208号", 
          "color": "#173177"
      } 
  },
  "emphasis_keyword": "keyword1.DATA" 
}

 

            var l = "https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=" + access_token;
            var tempData = new
            {
                touser = openid,
                template_id = "VErasH9Plzmyw9-PQjiggkBCa3hOU30qfvTaxD******",//这个是1、申请的模板消息id,
                page ="pages/index/index",
                form_id = formId,
                data = new
                {
                    keyword1 = new
                    {
                        value = title,
                        color = "#666666"
                    },
                    keyword2 = new
                    {
                        value = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
                        color = "#9b9b9b"
                    },
                    keyword3 = new
                    {
                        value = Remarks,
                        color = "#9b9b9b"
                    }
                },
                color = "#666666"
            };


            X.Component.Tools.WebClient wc = new X.Component.Tools.WebClient();
       
            var result = tempData.ToJson(); //Newtonsoft.Json.JsonConvert.SerializeObject(tempData);
       
            wc.Encoding = System.Text.Encoding.UTF8;
            var obj = wc.Post(l, result); //得到返回的结果

注意 page路径

最后返回的结果:

 

{
    "data": {
        "success": true
    }, 
    "statusCode": 200, 
    "header": {
        "Server": "Microsoft-IIS/7.5", 
        "Access-Control-Allow-Origin": "https://pubchem.ncbi.nlm.nih.gov", 
        "Cache-Control": "private", 
        "X-UA-Compatible": "chrome=1", 
        "Date": "Thu, 28 Sep 2017 04:46:34 GMT", 
        "X-AspNetMvc-Version": "4.0", 
        "Content-Type": "application/json; charset=utf-8", 
        "X-Powered-By": "ASP.NET", 
        "X-AspNet-Version": "4.0.30319", 
        "Content-Length": "16"
    }, 
    "errMsg": "request:ok"
}

 

效果截图:

 

微信小程序-发送模板消息(C#)_第2张图片

 

你可能感兴趣的:(微信小程序-发送模板消息(C#))