微信模板消息跳转小程序
点击微信模板消息跳转小程序后台实现
需求
实现效果
后台实现:
点击微信模板消息跳转小程序后台实现
需求
1.用户状态改变时,后台通过公众号给用户推送相关消息
2.用户点击推送消息跳转到小程序页面

实现效果

后台实现:
依赖

<!--微信模版消息推送三方sdk-->
        <dependency>
            <groupId>com.github.binarywang</groupId>
            <artifactId>weixin-java-mp</artifactId>
            <version>3.3.0</version>
        </dependency>
1
2
3
4
5
6
Java

/**
     * * 发送模板消息
     * pagepath 用户点击时需要跳转的小程序页面
     * openid 接收消息的用户openid
     * messageContent 推送消息主体内容
     */
    public static void sendTemplateMessage(String openid,String pagepath, String messageContent) {
        //配置公众号信息
        WxMpInMemoryConfigStorage wxStorage = new WxMpInMemoryConfigStorage();
        wxStorage.setAppId(tencentSubscriptionAppid);//appid 公众账号的唯一标识
        wxStorage.setSecret(tencentSubscriptionAppSecret);//appsecret 公众账号的密钥
        WxMpService wxMpService = new WxMpServiceImpl();
        wxMpService.setWxMpConfigStorage(wxStorage);
        //配置小程序信息
        WxMpTemplateMessage.MiniProgram miniProgram = new WxMpTemplateMessage.MiniProgram();
        miniProgram.setAppid(WxConfig.APP_ID);//小程序appid
        miniProgram.setUsePath(true);
        miniProgram.setPagePath("pages/index/index?id=222");//用户点击时需要跳转的小程序页面
       //配置模板信息
        WxMpTemplateMessage templateMessage = WxMpTemplateMessage.builder()
                .toUser(openid)//要推送的用户openid
                .templateId(templateTemplateID)//消息模版id
                //.url("http://mp.weixin.qq.com/download")//点击模版消息要访问的网址
                .miniProgram(miniProgram)
                .build();
        templateMessage.addData(new WxMpTemplateData("first","健康预警信息提示", "#FF00FF"));
        templateMessage.addData(new WxMpTemplateData("keyword1","红色预警", "#FF00FF"));
        templateMessage.addData(new WxMpTemplateData("keyword2","紧急处理", "#FF00FF"));
        templateMessage.addData(new WxMpTemplateData("remark",messageContent, "#FF00FF"));

//发起推送
        try {
            //String msg = wxMpService.getTemplateMsgService().sendTemplateMsg(templateMessage);-----这个方法有问题。参数转json的时候会将"pagepath"变为"path"导致不能够跳转到小程序指定页面。这里自行转换
           JSONObject parseObject = JSONObject.parseObject(templateMessage.toJson());
            JSONObject miniprogram = (JSONObject) parseObject.get("miniprogram");
            miniprogram.put("pagepath", miniprogram.get("path"));
            miniprogram.put("path", null);
            parseObject.put("miniprogram", miniprogram);

log.info("推送参数:" + parseObject);
            String responseContent = wxMpService.post(TEMPLATE_MESSAGE, parseObject.toJSONString());
            log.info("推送成功:" + responseContent);
        } catch (Exception e) {
            log.info("推送失败:" + e.getMessage());
            e.printStackTrace();
        }

}
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48

————————————————
版权声明:本文为CSDN博主「抚琴居士」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhh347713307/article/details/107047829/

微信模板消息跳转小程序相关推荐

  1. 微信模板消息跳转小程序指定页面(非首页)的问题

    需求 微信公众号发送模板消息,跳转到指定小程序的页面,可携带参数 问题点 文档 示例 根据官方文档的描述和示例展示,模板消息对象只要在miniprogram 对象中设置小程序的appid 和 page ...

  2. 微信公众号之模板消息跳转小程序

    公众号发送模板消息这里就不说了,详情可以去看我之前发的微信公众号开发之模板消息. 前几天因业务需求,需要点击模板消息跳转小程序,所以在此发篇博客记录一下. 代码如下: public void text ...

  3. 公众号推送模板消息,跳转小程序报错INVALID WEAPP PAGEPATH

    invalid weapp pagepath rid: 62d930f0-50070964-005e3fc6 这是微信示例: 在检查自己代码发现路径写错了.pagepath  要写对,前面可以不加斜线

  4. 公众号模板消息 跳转小程序报错invalid weapp pagepath解决方法

    官方文档示例: "miniprogram":{"appid":"xiaochengxuappid12345","pagepath& ...

  5. 通过微信模板消息跳转到小程序

    关注小编微信公众号公众号[前端基础教程从0开始]回复"1",拉你进程序员技术讨论群,群内有大神,可以免费提供问题解答.公众号回复"小程序",领取300个优秀的小 ...

  6. h5-浏览器点击跳转微信小程序或微信内部广告页(微信浏览器)跳转小程序的实现方法。

    一.微信内部浏览器使用<微信开放标签>唤起微信小程序 官方开发文档:[https://developers.weixin.qq.com/miniprogram/dev/framework/ ...

  7. 微信H5页面跳转小程序 - Vue中使用微信开放标签<wx-open-launch-weapp>

    微信开放标签说明文档 使用微信开放标签前置条件 1.绑定域名 登录微信公众平台进入"公众号设置"的"功能设置"里填写"JS接口安全域名" 2 ...

  8. 微信公众号跳转小程序 wx-open-launch-weapp (最全指南及坑)

    微信公众号使用 wx-open-launch-weapp 开放标签跳转小程序 注意事项 微信开放标签有最低的微信版本要求,以及最低的系统版本要求. 微信版本要求为:7.0.12及以上 系统版本要求为: ...

  9. uniapp 微信公众号跳转小程序的各种坑

    一.引进js http://res2.wx.qq.com/open/js/jweixin-1.6.0.js import wx from "jweixin-module"; let ...

  10. java发送小程序模板消息,记录_小程序发送模板消息

    package com.mj.frame.entity.resp; import java.io.Serializable; import java.util.List; import java.ut ...

最新文章

  1. Xamarin Visual Studio提示找不到AssemblyAttributes.cs文件
  2. c#判断右键菜单(ContextMenuStrip)是从哪个控件弹出来的方法
  3. 1.VMware安装3个ubuntu14.05
  4. curl获取结果乱码的解决方法之CURLOPT_ENCODING(curl/Post请求)
  5. python实现一个字典
  6. (转)二维平面坐标系-最近点对模板
  7. C++ STL 容器之queue
  8. 【转】在WPF中自定义控件
  9. 获取进程的信息 linux,如何获取进程信息
  10. 个类似GoogleMap的客户端JS开源库
  11. C# 使用DataMatrix.net.dll进行二维码打印
  12. 数组元素全排列、组合 C语言代码
  13. 2022腾讯云双十一服务器价格出炉来看看便宜不
  14. 偶得李春芬先生书信一函
  15. ant-design-vue对起始时间的校验
  16. 主题狗themes.dog-精选上百种优秀开源网站主题、博客主题、商城模板
  17. 欢乐的票圈重构——九宫格控件(上)
  18. NameError: name 'mnist' is not defined
  19. 微信支付宝支付如何盈利?盈利如何?
  20. 快服务助手卡片测试时为什么不跳转线上快应用?

热门文章

  1. 周立功TinyM0开发板1114使用教程
  2. 3D材质管理软件Adobe Substance 3D Sampler中文版
  3. mysql批量执行语句_mysql批量执行sql语句
  4. 【2020年“科创中国”】先导技术榜单、新锐企业榜单、产学研融通组织榜单发
  5. 如何前后端分离的架构中使用Shiro框架
  6. STM32烧写程序:Keil5使用ST-link下载程序
  7. 一元线性回归(最小二乘法)
  8. 计算机英语听力速记...,2019考研计算机英语听力速记技巧
  9. 前后端分离微服务管理系统项目实战SaaS-HRM项目(七)——POI报表入门
  10. 回顾安全多方计算-SMPC(MPC)