文章目录
  1. 1. 1.传统方式实现模板消息
  2. 2. 2、基于Bmob后端云的模板消息实现

1.传统方式实现模板消息

1、获取openId

2、获取模板ID

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

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

登录https://mp.weixin.qq.com 获取模板,如果没有合适的模板,可以申请添加新模板,审核通过后可使用

3、获取access_token

access_token 的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的 access_token 失效

公众平台的 API 调用所需的 access_token 的使用及生成方式说明:

1. 为了保密 appsecrect,第三方需要一个 access_token 获取和刷新的中控服务器。而其他业务逻辑服务器所使用的access_token 均来自于该中控服务器,不应该各自去刷新,否则会造成 access_token 覆盖而影响业务;
2. 目前 access_token 的有效期通过返回的 expires_in来传达,目前是7200秒之内的值。中控服务器需要根据这个有效时间提前去刷新新access_token。在刷新过程中,中控服务器对外输出的依然是老access_token,此时公众平台后台会保证在刷新短时间内,新老 access_token 都可用,这保证了第三方业务的平滑过渡;
3. access_token 的有效时间可能会在未来有调整,所以中控服务器不仅需要内部定时主动刷新,还需要提供被动刷新access_token 的接口,这样便于业务服务器在 API 调用获知 access_token 已超时的情况下,可以触发access_token 的刷新流程。

开发者可以使用 AppID 和 AppSecret 调用本接口来获取 access_token。AppID 和 AppSecret 可登录微信公众平台官网-设置-开发设置中获得(需要已经绑定成为开发者,且帐号没有异常状态)。AppSecret 生成后请自行保存,因为在公众平台每次生成查看都会导致 AppSecret 被重置。注意调用所有微信接口时均需使用 https 协议。如果第三方不使用中控服务器,而是选择各个业务逻辑点各自去刷新 access_token,那么就可能会产生冲突,导致服务不稳定

以上内容是微信开发文档给出的access_token的说明,总的来说就是两点

(1)access_token是发送模板消息的凭证,需要用微信小程序的AppID 和AppSecret 调用接口来获取,有效时间为2小时
(2)如果在此获取access_token则会导致前一个access_token失效,有多个公众号和小程序的开发者一定要注意这一点!

接口地址:

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

GET请求

参数说明 :
| 参数|必填 | 说明|
|–|–| –|
| grant_type | 是 | 获取 access_token 填写 client_credential |
| appid | 是 | 第三方用户唯一凭证 |
| secret | 是 | 第三方用户唯一凭证密钥,即appsecret |

1
2
3
4
5
6
7
function onRequest(request, response, modules) {
var http = modules.oHttp;
//发起Get请求
http('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=XXX&secret=XXX', function (error, res, body) {
response.send(body);
});
}

结果:

1
2
3
4
5
6
Response Body
{
"code": 200,
"msg":
{"access_token":"6_R8kOFxRLeRtWOq_haIU29XB0hbAoKxFGRqQTZt_HhzCSEvT_xDJ4WLgf9A_dt2pRTCugfUk7IkxR2sfu5zckCwKKWEghCtqlrrQlhdJmCxmkBAaDEdW7AU98D23rUJO5PYruNYOLQ3cpH3iAVTNiADAECW","expires_in":7200}
}

发送模板消息
接口地址:(ACCESS_TOKEN 需换成上文获取到的 access_token)

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

POST请求

POST参数说明:
| 参数|必填 | 说明|
|–|–| –|
| touser | 是 | 接收者(用户)的 openid |
| template_id | 是 | 所需下发的模板消息的id |
| page | 否 | 点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。 |
| form_id | 是 | 表单提交场景下,为 submit 事件带上的 formId;支付场景下,为本次支付的 prepay_id |
| data | 是 | 模板内容,不填则下发空模板 |
| color| 否 | 模板内容字体的颜色,不填默认黑色 |
| emphasis_keyword| 否 | 模板需要放大的关键词,不填则默认无放大 |

formid说明:页面的

组件,属性report-submit为true时,可以声明为需发模板消息,此时点击按钮提交表单可以获取formId

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
var temp = {
"touser": touser,//用户的openid
"template_id": template_id,//模板id
"page": "",
"form_id": formid,//表单id
"data": {
"keyword1": {
"value": title,
"color": "#173177"
},
"keyword2": {
"value": gettime()
},
},
"emphasis_keyword": "keyword1.DATA" //将keyword1放大
}

测试效果:
在这里插入图片描述

2、基于Bmob后端云的模板消息实现

第一种方法实现起来过于繁琐,在使用过程中也要中间服务器的帮助,如果没有中间服务器,或者服务器端的代码不太熟悉,那么Bmob后端云则可以帮助你实现你要的功能

只需要下载按照官网文档在小程序内初始化好Bmob,那么就可以调用Bmob模板消息的方法,如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
function send(title, formid, touser){
var Bmob = require('bmob.js');
var temp = {
"touser": touser,
"template_id": "ClYq9lc8bZh26uM993NNIknasAVBdk0wSYnDrkClK40",
"page": "",
"form_id": formid,
"data": {
"keyword1": {
"value": title,
"color": "#173177"
},
"keyword2": {
"value": gettime()
},

},
"emphasis_keyword": "keyword1.DATA"
}

Bmob.sendMessage(temp).then(function (obj) {
console.log('发送成功');
},
function (err) {
common.showTip('失败' + err)
});
}

这样模板消息就解决了!!!

文章目录
  1. 1. 1.传统方式实现模板消息
  2. 2. 2、基于Bmob后端云的模板消息实现