微信小程序发送模板消息
微信小程序发送模板消息
标签(空格分隔): 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这条数据;
}
微信小程序发送模板消息的更多相关文章
- 微信小程序 发送模板消息的功能实现
背景 - 小程序开发的过程中,绝大多数会满足微信支付 - 那么,作为友好交互的体现,自然就会考虑到支付后的消息通知咯 - 所以,我的小程序项目也要求完成这个效果,so.分享一下自己的实现步骤,以方便道 ...
- 微信小程序-发送模板消息
1 添加一个小程序的消息模板,获取到模板id,存储到数据库中,方便以后修改调用 2. https://developers.weixin.qq.com/miniprogram/dev/api-back ...
- 微信小程序-发送模板消息(C#)
步骤一:获取模板ID 有两个方法可以获取模版ID 通过模版消息管理接口获取模版ID 在微信公众平台手动配置获取模版ID 步骤二:页面的 <form/> 组件,属性report-submit ...
- 微信小程序开发模板消息的时候 出现 errcode: 41028, errmsg: "invalid form id hint:
小程序开发模板消息的时候 出现 errcode: 41028, errmsg: "invalid form id hint: 我是使用的微信支付发送模板消息,提示的formid无效的 大家 ...
- Python 发送微信小程序的模板消息
在小程序的开发过程中,会存在模板消息的发送,具体文档见 这里,模板消息的发送是和语言无关的,这里将简要写一下怎么用 Python 给用户发送模板消息. 通过文档可以知道,发送的时候,需要使用小 ...
- 微信小程序 发送模版消息
微信小程序开发之发送模板消息 1,小程序wxml页面form表单添加 report-submit="true" <form bindsubmit="sub" ...
- 微信小程序的模板消息与小程序订阅消息
小程序订阅消息 功能介绍 消息能力是小程序能力中的重要组成,我们为开发者提供了订阅消息能力,以便实现服务的闭环和更优的体验. 订阅消息推送位置:服务通知 订阅消息下发条件:用户自主订阅 订阅消息卡片跳 ...
- 微信小程序之模板消息推送
最近在用sanic框架写微信小程序,其中写了一个微信消息推送,还挺有意思的,写了个小demo 具体见官方文档:https://developers.weixin.qq.com/miniprogram/ ...
- .netcore 3.1 C# 微信小程序发送订阅消息
一.appsettings.json定义小程序配置信息 "WX": { "AppId": "wx88822730803edd44", &qu ...
随机推荐
- 深入分析setContentView
在网络层,互联网提供所有应用程序都要使用的两种类型的服务,尽管目前理解这些服务的细节并不重要,但在所有TCP/IP概述中,都不能忽略他们: 无连接分组交付服务(Connectionless Packe ...
- Linux目录结构(二)
Linux文件系统结的结构是树形结构,其入口从/开始,了解Linux文件系统的结构,对于我们需要掌握的基础知识点之一. 2.文件系统的组织结构简说: 当您使用Linux的时候,如果您通过ls -la ...
- swiper套路
swiper插件 quick start 基本结构 <div class="swiper-container"> <div class="swiper- ...
- (转)使用Vue-Router 2实现路由功能
注意:vue-router 2只适用于Vue2.x版本,下面我们是基于vue2.0讲的如何使用vue-router 2实现路由功能.推荐使用npm安装. npm install vue-router ...
- jquery mobile动态加载数据后无法渲染
引自:http://blog.sina.com.cn/s/blog_025270e901016lst.html jquery mobile在动态添加html之后无法渲染控件,无法转换控件的办法! jq ...
- CV与IP:基础,经典以及最近发展
原文链接:http://blog.csdn.net/dcraw/article/details/7617891 原文编写层层递进,逻辑清晰: 不过看这篇转载可以少点击鼠标:http://blog.cs ...
- html IMG 标签水平居中 ,和图片过大 溢出处理
max-width: 100%;//父元素的宽度 display: block; margin: 0 auto; display: table-cell; 垂直居中 vertical-align: m ...
- JS 封装一个求圆面积的函数 传值:半径
y(6) var s = ""; function y (r){ s = Math.PI*r*r; alert(s); }
- BZOJ 1221 [HNOI2001] 软件开发 费用流_建模
题目描述: 某软件公司正在规划一项n天的软件开发计划,根据开发计划第i天需要ni个软件开发人员,为了提高软件开发人员的效率,公司给软件人员提供了很多的服务,其中一项服务就是要为每个开发人员每天提供 ...
- Nginx负载均衡health_check分析
在Nginx负载均衡中,我们很难保证说每一台应用服务器都能一直正常的运行下去.但是我们可以通过设置Nginx来检测这些应用服务器,检测这些服务器当中不能访问的. Nginx的检测方式分为两种,一种是被 ...