微信小程序发送模板消息

标签(空格分隔): php


看小程序文档

【模板消息文档总览】:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/template-message.html

【发送模板消息】:https://developers.weixin.qq.com/miniprogram/dev/api/open-api/template-message/sendTemplateMessage.html

【先看一下模板消息的效果】

分析模板消息

发送模板消息【url和参数】

【Url】 https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token=ACCESS_TOKEN
【Method】POST
【Params】: {
"touser": "OPENID",
"template_id": "TEMPLATE_ID",
"page": "index",
"form_id": "FORMID",
"data": {
"keyword1": {
"value": "339208499"
},
"keyword2": {
"value": "2015年01月05日 12:30"
},
"keyword3": {
"value": "腾讯微信总部"
} ,
"keyword4": {
"value": "广州市海珠区新港中路397号"
}
},
"emphasis_keyword": "keyword1.DATA"
} touser :要发送用户的openid
template_id : 模板id编号【待会儿创建】
page :点击模板消息跳转的页面
form_id : 就是formid 需要去收集用户的formid
data:就是发送的内容
keyword1:一一对应模板的内容
keywork2:一一对应模板的内容
emphasis_keyword:可以忽略【模板需要放大的关键词,不填则默认无放大】

第一步:创建模板-记录模板id[template_id]

登录公众平台:-> 模板消息 -> 添加

记录模板id到数据库【根据项目需求来决定,多个小程序的话通过程序生成统一管理】

第二步:收集formId[form_id]

前端form表单:

注意:
1 要存储formid和对应的openid【每个用户每天最多10个,用一个删一个】 2 因为我们是在开发者工具中测试,所以得到的formId值为the formId is a mock one。所以测试真实场景务必在真机中测试

第三步:代码

/**
* @param $params [参数]
* @param $appid [小程序appid]
* @param $secret [小程序secret]
* @param $type [模板消息的类型] 如:审核,通知, 签到 。。。。
*/
public function templateMessage($params, $appid, $secret, $type)
{
# 获取模板信息
$tpl = $this->template(['appid'=>$appid, 'type'=>$type]); # 模板关键字
$data = [];
foreach ($params['data'] as $k => $v) {
$data['keyword'.($k+1)] = ['value'=>$v];
} $postData = [
'touser' => $params['openid'],
'template_id' => $tpl['tpl_id'],
'page' => $params['page'],
'form_id' => $params['form_id'],
'data' => $data
]; # user_token 必须全局获取|存储 $url = 'https://api.weixin.qq.com/cgi-bin/message/wxopen/template/send?access_token='.self::getUserToken($appid, $secret); $ret = curl($url, $postData); /* 成功返回
{
"errcode": 0,
"errmsg": "ok",
"template_id": "wDYzYZVxobJivW9oMpSCpuvACOfJXQIoKUm0PY397Tc"
}
*/
return $ret;
} # 发送模板消息
public function hello()
{
$appid = 'xxxxxxxxxxx';
$secret = 'xxxxxxxxxxx'; $data = [
'openid' => 'openid',
'page' => 'pages/index/index',
'form_id' => '拿openid去查', 【收集formid的表】
'data' => [
keyword1,
keyword2,
keywrod3,
........
]
]; $ret = $this->templateMessage($data, $appid, $secret, '1'); 删除formid这条数据;
}

微信小程序发送模板消息的更多相关文章

  1. 微信小程序 发送模板消息的功能实现

    背景 - 小程序开发的过程中,绝大多数会满足微信支付 - 那么,作为友好交互的体现,自然就会考虑到支付后的消息通知咯 - 所以,我的小程序项目也要求完成这个效果,so.分享一下自己的实现步骤,以方便道 ...

  2. 微信小程序-发送模板消息

    1 添加一个小程序的消息模板,获取到模板id,存储到数据库中,方便以后修改调用 2. https://developers.weixin.qq.com/miniprogram/dev/api-back ...

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

    步骤一:获取模板ID 有两个方法可以获取模版ID 通过模版消息管理接口获取模版ID 在微信公众平台手动配置获取模版ID 步骤二:页面的 <form/> 组件,属性report-submit ...

  4. 微信小程序开发模板消息的时候 出现 errcode: 41028, errmsg: "invalid form id hint:

    小程序开发模板消息的时候  出现 errcode: 41028, errmsg: "invalid form id hint: 我是使用的微信支付发送模板消息,提示的formid无效的 大家 ...

  5. Python 发送微信小程序的模板消息

    在小程序的开发过程中,会存在模板消息的发送,具体文档见 这里,模板消息的发送是和语言无关的,这里将简要写一下怎么用 Python 给用户发送模板消息.     通过文档可以知道,发送的时候,需要使用小 ...

  6. 微信小程序 发送模版消息

    微信小程序开发之发送模板消息 1,小程序wxml页面form表单添加 report-submit="true" <form bindsubmit="sub" ...

  7. 微信小程序的模板消息与小程序订阅消息

    小程序订阅消息 功能介绍 消息能力是小程序能力中的重要组成,我们为开发者提供了订阅消息能力,以便实现服务的闭环和更优的体验. 订阅消息推送位置:服务通知 订阅消息下发条件:用户自主订阅 订阅消息卡片跳 ...

  8. 微信小程序之模板消息推送

    最近在用sanic框架写微信小程序,其中写了一个微信消息推送,还挺有意思的,写了个小demo 具体见官方文档:https://developers.weixin.qq.com/miniprogram/ ...

  9. .netcore 3.1 C# 微信小程序发送订阅消息

    一.appsettings.json定义小程序配置信息 "WX": { "AppId": "wx88822730803edd44", &qu ...

随机推荐

  1. 深入分析setContentView

    在网络层,互联网提供所有应用程序都要使用的两种类型的服务,尽管目前理解这些服务的细节并不重要,但在所有TCP/IP概述中,都不能忽略他们: 无连接分组交付服务(Connectionless Packe ...

  2. Linux目录结构(二)

    Linux文件系统结的结构是树形结构,其入口从/开始,了解Linux文件系统的结构,对于我们需要掌握的基础知识点之一. 2.文件系统的组织结构简说: 当您使用Linux的时候,如果您通过ls -la ...

  3. swiper套路

    swiper插件 quick start 基本结构 <div class="swiper-container"> <div class="swiper- ...

  4. (转)使用Vue-Router 2实现路由功能

    注意:vue-router 2只适用于Vue2.x版本,下面我们是基于vue2.0讲的如何使用vue-router 2实现路由功能.推荐使用npm安装. npm install vue-router ...

  5. jquery mobile动态加载数据后无法渲染

    引自:http://blog.sina.com.cn/s/blog_025270e901016lst.html jquery mobile在动态添加html之后无法渲染控件,无法转换控件的办法! jq ...

  6. CV与IP:基础,经典以及最近发展

    原文链接:http://blog.csdn.net/dcraw/article/details/7617891 原文编写层层递进,逻辑清晰: 不过看这篇转载可以少点击鼠标:http://blog.cs ...

  7. html IMG 标签水平居中 ,和图片过大 溢出处理

    max-width: 100%;//父元素的宽度 display: block; margin: 0 auto; display: table-cell; 垂直居中 vertical-align: m ...

  8. JS 封装一个求圆面积的函数 传值:半径

    y(6) var s = ""; function y (r){ s = Math.PI*r*r; alert(s); }

  9. BZOJ 1221 [HNOI2001] 软件开发 费用流_建模

    题目描述:   某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供 ...

  10. Nginx负载均衡health_check分析

    在Nginx负载均衡中,我们很难保证说每一台应用服务器都能一直正常的运行下去.但是我们可以通过设置Nginx来检测这些应用服务器,检测这些服务器当中不能访问的. Nginx的检测方式分为两种,一种是被 ...