templateMessage.send

本接口应在服务器端调用,详细说明参见服务端API

本接口支持云调用。需开发者工具版本 >= 1.02.1904090(最新稳定版下载),wx-server-sdk >= 0.4.0

组合模板并添加至帐号下的个人模板库(请注意,小程序模板消息接口将于2020年1月10日下线,开发者可使用订阅消息功能

调用方式:

HTTPS 调用

请求地址

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

请求参数

属性类型默认值必填说明
access_tokenstring接口调用凭证
touserstring接收者(用户)的 openid
template_idstring所需下发的模板消息的id
pagestring点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。
form_idstring表单提交场景下,为 submit 事件带上的 formId;支付场景下,为本次支付的 prepay_id
dataObject模板内容,不填则下发空模板。具体格式请参考示例。
emphasis_keywordstring模板需要放大的关键词,不填则默认无放大

返回值

Object

返回的 JSON 数据包

属性类型说明
errcodenumber错误码
errmsgstring错误信息

errcode 的合法值

说明最低版本
40037template_id不正确
41028form_id不正确,或者过期
41029form_id已被使用
41030page不正确
45009接口调用超过限额(目前默认每个帐号日调用限额为100万)

请求示例

  1. {
  2. "touser": "OPENID",
  3. "template_id": "TEMPLATE_ID",
  4. "page": "index",
  5. "form_id": "FORMID",
  6. "data": {
  7. "keyword1": {
  8. "value": "339208499"
  9. },
  10. "keyword2": {
  11. "value": "2015年01月05日 12:30"
  12. },
  13. "keyword3": {
  14. "value": "腾讯微信总部"
  15. } ,
  16. "keyword4": {
  17. "value": "广州市海珠区新港中路397号"
  18. }
  19. },
  20. "emphasis_keyword": "keyword1.DATA"
  21. }

返回示例

  1. {
  2. "errcode": 0,
  3. "errmsg": "ok"
  4. }

云调用

云调用是小程序·云开发提供的在云函数中调用微信开放接口的能力,需要在云函数中通过 wx-server-sdk 使用。

接口方法

  1. openapi.templateMessage.send

需在 config.json 中配置 templateMessage.send API 的权限,详情

请求参数

属性类型默认值必填说明
touserstring接收者(用户)的 openid
templateIdstring所需下发的模板消息的id
pagestring点击模板卡片后的跳转页面,仅限本小程序内的页面。支持带参数,(示例index?foo=bar)。该字段不填则模板无跳转。
formIdstring表单提交场景下,为 submit 事件带上的 formId;支付场景下,为本次支付的 prepay_id
dataObject模板内容,不填则下发空模板。具体格式请参考示例。
emphasisKeywordstring模板需要放大的关键词,不填则默认无放大

返回值

Object

返回的 JSON 数据包

属性类型说明
errCodenumber错误码
errMsgstring错误信息

errCode 的合法值

说明最低版本
0成功

异常

Object

抛出的异常

属性类型说明
errCodenumber错误码
errMsgstring错误信息

errCode 的合法值

说明最低版本
40037template_id不正确
41028form_id不正确,或者过期
41029form_id已被使用
41030page不正确
45009接口调用超过限额(目前默认每个帐号日调用限额为100万)

请求示例

  1. const cloud = require('wx-server-sdk')
  2. cloud.init()
  3. exports.main = async (event, context) => {
  4. try {
  5. const result = await cloud.openapi.templateMessage.send({
  6. touser: 'OPENID',
  7. page: 'index',
  8. data: {
  9. keyword1: {
  10. value: '339208499'
  11. },
  12. keyword2: {
  13. value: '2015年01月05日 12:30'
  14. },
  15. keyword3: {
  16. value: '腾讯微信总部'
  17. },
  18. keyword4: {
  19. value: '广州市海珠区新港中路397号'
  20. }
  21. },
  22. templateId: 'TEMPLATE_ID',
  23. formId: 'FORMID',
  24. emphasisKeyword: 'keyword1.DATA'
  25. })
  26. console.log(result)
  27. return result
  28. } catch (err) {
  29. console.log(err)
  30. return err
  31. }
  32. }

返回示例

  1. {
  2. "errCode": 0,
  3. "errMsg": "openapi.templateMessage.send:ok"
  4. }