欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#开发之微信小程序发送模板消息功能

程序员文章站 2023-12-17 09:32:34
步骤一:获取模板id 有两个方法可以获取模版id 通过模版消息管理接口获取模版id 在微信公众平台手动配置获取模版id 步骤二:页面的

步骤一:获取模板id

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

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

步骤二:页面的 <form/> 组件,属性report-submit为true时,可以声明为需发模板消息,此时点击按钮提交表单可以获取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

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

官方的post参数:

C#开发之微信小程序发送模板消息功能

{
 "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#开发之微信小程序发送模板消息功能

总结

以上所述是小编给大家介绍的c#开发之微信小程序发送模板消息功能,希望对大家有所帮助

上一篇:

下一篇: