做过微信开发的应该都有一点感触,就是他的开发文档不是一成不变的,接口有时候会被下线,但也不是一下子就不能用了,一般会兼容旧接口,然后提醒你使用新接口有更多好处。如果接口真的直接下线了,也会提供另一种能够实现相同功能的接口给你替换。所以有天你以为代码都写好了,没有bug了,悠哉悠哉的时候,忽然产品经理说微信的哪个接口不能用了,快去改一下,不要惊讶,老老实实去改就对了哈。

这不,微信将小程序的模板消息接口下线了,之前用formid来调这个接口的功能都就用不了了。

看官方文档提示,是提供了订阅消息的功能来替换,顾名思义,要用户主动订阅了才可以发送成功,像下面这样:

除了这种订阅消息外,还有没有其他方法来实现同等效果呢,答案是of course。

翻阅小程序开发文档发现,官方还提供了一个统一服务消息的接口。为便于开发者对用户进行服务消息触达,简化小程序和公众号模板消息下发流程,小程序提供统一的服务消息下发接口。就是在小程序里发送公众号模板消息,这个好处就是不需要formid的,文档地址:

https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/uniform-message/uniformMessage.send.html

要注意:以下几类消息是目前不允许发的模板消息

1、模板内容与服务场景(含标题、关键词)不一致的模板

2、涉嫌广告营销类消息模板

3、发送频率过高,有骚扰用户倾向类消息模板

4、涉及红包、卡券、优惠券、代金券、会员卡、积分类消息模板

接下来我们就来实现下,效果在文末

1、准备

调用这个接口的前提是公众号和小程序有绑定且是同主体的,这个好办,登录公众号后台 -> 小程序 -> 小程序管理 -> 添加即可绑定小程序

因为实质上还是发的公众号模板消息,所以还是要在公众号后台添加消息模板获取模板id

2、开发

好了,做好以上两个准备就可以开发了,主要代码如下面:

/*** 在小程序里使用同主体的关联公众号发送模板消息* https://developers.weixin.qq.com/doc/offiaccount/Message_Management/Template_Message_Interface.html* @param vo* @return   {"errcode":0,"errmsg":"ok"}   向没有关注公众号的用户发送会返回{"errcode":43004,"errmsg":"require subscribe hint: [LGcpYa05528672]"}*/public static JSONObject uniformSend(SendVo vo){boolean flag = false;JSONObject object = new JSONObject();JSONObject mpTemplateMsg = new JSONObject();JSONObject miniprogram = new JSONObject();String url = "https://api.weixin.qq.com/cgi-bin/message/wxopen/template/uniform_send?access_token="+vo.getToken();object.put("touser", vo.getToUser());mpTemplateMsg.put("appid", vo.getPublicAppId());mpTemplateMsg.put("url", vo.getUrl());mpTemplateMsg.put("template_id", vo.getTemplateId());miniprogram.put("appid",vo.getMiniAppId());miniprogram.put("pagepath",vo.getPagePath());mpTemplateMsg.put("miniprogram",miniprogram);List<String> list = vo.getValue();JSONObject jsonObject = null;if (list != null && list.size() > 0) {int size = list.size();JSONObject data = new JSONObject();for (int i = 0; i < size; i++) {if (i == 0) {JSONObject first = new JSONObject();first.put("value",list.get(0));first.put("color",vo.getColor());data.put("first",first);} else if (i == size-1) {JSONObject remark = new JSONObject();remark.put("value",list.get(0));remark.put("color",vo.getColor());data.put("remark",remark);} else {JSONObject keyword = new JSONObject();keyword.put("value",list.get(i));keyword.put("color",vo.getColor());data.put("keyword"+i,keyword);}}mpTemplateMsg.put("data",data);object.put("mp_template_msg",mpTemplateMsg);jsonObject = CommonUtil.httpsRequestJson(url, "POST", object.toJSONString());logger.info("统一消息推送模板json======{}",jsonObject);}return jsonObject;}

针对入参要说下mpTemplateMsg.put(“data”,data)里面的data这个参数,它是first.DATA,

(keyword1.DATA,keyword2.DATA。。。),remark.DATA组成的,所以for循环里面

拼接数据的时候要分三个,分别对应first.DATA,(keyword1.DATA,keyword2.DATA。。。),remark.DATA的字段值。

3、效果

微信小程序模板消息接口下线了,不用慌,调用统一服务消息接口来实现相同功能相关推荐

  1. 微信小程序模板消息群发、无限制推送相关讲解

    模版消息推送是微信小程序采用的通知形式,用户本人在小程序页面有交互行为后,可触发下发通知,通过微信聊天列表中的服务通知可快捷进入查看消息.此外,点击查看详情还能跳转到下发消息的小程序的指定页面.但是为 ...

  2. 【转】微信小程序模板消息无限制群发

    模版消息推送是微信小程序采用的通知形式, 用户本人在小程序页面有交互行为后,可触发下发通知 ,通过微信聊天列表中的服务通知可快捷进入查看消息.此外,点击查看详情还能跳转到下发消息的小程序的指定页面.但 ...

  3. 微信小程序模板消息无限制群发

    模版消息推送是微信小程序采用的通知形式, 用户本人在小程序页面有交互行为后,可触发下发通知 ,通过微信聊天列表中的服务通知可快捷进入查看消息.此外,点击查看详情还能跳转到下发消息的小程序的指定页面.但 ...

  4. 微信小程序模板消息还能群发?无限制推送?

    模版消息推送是微信小程序采用的通知形式,用户本人在小程序页面有交互行为后,可触发下发通知,通过微信聊天列表中的服务通知可快捷进入查看消息.此外,点击查看详情还能跳转到下发消息的小程序的指定页面.但是为 ...

  5. 突破微信小程序模板消息的推送限制

    "模版消息"是小程序非常重要且可主动触达用户的一种能力.爱鲜蜂小程序通过"模版消息",建立一套用户唤醒机制,达到提升用户复购率的目的.小打卡小程序的近30天访问 ...

  6. 微信小程序模板消息(服务通知消息)原始post工具封装(不使用jar包--坑比较多),解决47001(JSON格式)和中文乱码问题

    微信小程序模板消息(服务通知消息)原始post工具封装(不使用jar包--坑比较多),解决47001(JSON格式)和中文乱码问题 参考文章: (1)微信小程序模板消息(服务通知消息)原始post工具 ...

  7. 微信小程序模板消息群发解决思路

    基于微信的通知渠道,微信为开发者提供了可以高效触达用户的模板消息能力,以便实现服务的闭环并提供更佳的体验.(微信6.5.2及以上版本支持模板功能.低于该版本将无法收到模板消息.) 模板推送位置:服务通 ...

  8. 微信小程序-模板消息

    基于微信的通知渠道,微信为开发者提供了可以高效触达用户的模板消息能力,以便实现服务的闭环并提供更佳的体验.(微信6.5.2及以上版本支持模板功能.低于该版本将无法收到模板消息.) 模板推送位置:服务通 ...

  9. php实现微信小程序推送,实现微信小程序模板消息不受限制、无限主动推送

    需求背景 基于微信的通知渠道,微信小程序为开发者提供了可以高效触达用户的模板消息能力,在用户本人与小程序页面有交互行为后触发,通过微信聊天列表中的服务通知可快捷进入查看消息,点击查看详情还能跳转到下发 ...

  10. 微信小程序-模板与配置

    1.数据绑定 1.1.数据绑定的基本原则 在 data 中定义数据 在 WXML 中使用数据 1.2.在 data 中定义页面的数据 # 在页面对应的 .js 文件中,把数据定义到 data 对象中即 ...

最新文章

  1. spring对JDBC的支持
  2. 第二阶段站立会议08
  3. html页面text固定长度,HTML中input type=text和type=password 显示的长度不一样
  4. js处理16进制hex转str出现的中文乱码问题
  5. 2压缩备份数据库_达梦数据库备份与还原
  6. 开源项目到底归谁管?
  7. 简明python教程电子书下载_简明Python教程PDF
  8. Cisco dynamips模拟器安装指南
  9. 【软件相关】Proteus 8入门教程
  10. kaggle泰坦尼克
  11. disabled与enabled是什么?disabled与enabled属性详解
  12. 下面哪个linux内核是稳定版本,哪个 Linux 内核版本是 “稳定的”?
  13. 服务器手机信息报警,广东肇庆110全面开通手机短信报警服务
  14. VisualNet地税管网综合资源管理系统
  15. 提高php代码质量 36计
  16. kubernetes健康检查配置解析
  17. const int a = 100; 这种引用虽然可以, 但要少用或者不用
  18. C语言 计算e的近似值
  19. 一汽轿车拟增资摩拜出行;甘薇出售资产代夫偿债;小米越南店正式开业丨价值早报
  20. 【安全知识分享】新员工公司级安全生产教育培训(附下载)

热门文章

  1. DOP反映的是测量误差与定位误差之间的传递关系。
  2. PHP傻瓜式一键建站系统源码+无需授权
  3. android tv 国内使用,不花钱解决 Android TV 原生系统国内APP不显示图标
  4. 中文分词 正向最大匹配法 逆向最大匹配法 双向最大匹配法
  5. java后台amr格式转mp3格式方法
  6. 三菱FX5U常见问题解析
  7. 安装Python教程(Mac)保姆级教程
  8. 信号指示RSSI与显示格数关系
  9. Web安全——同源策略理解
  10. 计算机播放音乐没声音为什么,电脑没声音是怎么回事?教你怎么修复