评论

如何在微信内外部浏览器唤起小程序

如何使用h5唤起微信小程序

微信外部浏览器唤起微信小程序

目的:通过发送短信召回流失用户。

官方文档地址

步骤一

  • 该API我们主要用到的配置如下:
  • jump_wxa:跳转到的目标小程序信息。该对象内包含两个字段。
  • path:通过scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query
  • query:通过scheme码进入小程序时的query。

步骤二

  • 需要注意的是,query必传,然而如果我们需要跳转的页面不需要参数,也需要配置上query,默认我们填写的是from=sms, 用于统计是从短信渠道来的。

步骤三

  • 与后端约定access_token 通过前端传递appKey进行区分,传哪个微信小程序的appKey 就生成对应小程序的access_token。

步骤四

  • 支持设置scheme的过期时间,默认永久,我们的应用场景很少,暂不详说。

步骤五

  • 代码里操作如下,由后端聚合参数信息。
let postData = {
  appKey: 'QTSHE_MINI_APP',
  path: 'pages/partdetails/partdetails',
  query: 'partJobId=123456' || 'a=1'
}
this.$axios.post('xxx', postData).then((res) => {
  if (res.success) {
    const url = res.data.openlink
    // 将scheme转为我们平台的短链接,否则在安卓手机上无法打开微信小程序,会默认打开浏览器搜索。
    this.$axios.get(`xxx`, {url}).then((res) => {
      if (res.success) {
        this.shortLink = res.data // 将weixin://xxxx 转换为 https://b.qtshe.com/xxx
      }
    })
  } else {
    this.$Message.error('获取失败,请稍后重试')
  }
}).catch((err) => {
  console.log(err)
  this.$Message.error('获取失败,请稍后重试')
})


微信内部浏览器唤起小程序

官方文档地址

步骤一

  • 首先需要登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”,未配置会导致wx.config签名失败,导致无法使用开放标签。

步骤二

步骤三

  • 通过config接口注入权限验证配置并申请所需开放标签, 在wx.config里增加openTagList标签,内置两个开放标签 wx-open-launch-app 微信h5唤起本地已经安装的app,以及 wx-open-launch-weapp 微信h5唤起小程序,操作如下:
wx.config({
  debug: false,
  appId: window.g_info.wx_appid, // 全局变量appId
  timestamp: data.data.timestamp, // 调用微信接口返回的
  nonceStr: data.data.nonceStr, // 调用微信接口返回的
  signature: data.data.signature, // 调用微信接口返回的
  jsApiList: ['openLocation', 'getLocation'], // 这里需要任意填写api,不能为空
  openTagList: [
    'wx-open-launch-app',
    'wx-open-launch-weapp'
  ]
})

注意点

  • 对于Vue等视图框架,为了避免template标签冲突的问题,可使用<script type="text/wxtag-template"></script>进行代替,来包裹插槽模版和样式。
  • 页面中与布局和定位相关的样式,如position: fixed; top -100;等,尽量不要写在插槽模版的节点中,请声明在标签或其父节点上;
  • 对于有CSP要求的页面,需要添加白名单frame-src https://*.qq.com webcompt:,才能在页面中正常使用开放标签。
// Vue里操作代码如下,如果需要写样式,最好是外部包一个div进行样式编写,内部的内容宽高100%即可,调试样式可使用微信开发者工具的网页模式:

.quick-btn {
  // 这里写样式
  width: 3.43rem;
  height: 0.96rem;
  display: flex;
  img {
    width: 100%;
    display: block;
  }
}

<div class="quick-btn">
  <img src="https://qiniu-image.qtshe.com/20220317quick-apply.png" alt="" />
</div>


示例效果


为了方便运营同学,做了个工具给他们使用。


2023年4.11号新版本后的改版方案:

首先做一个落地页:https://b.qtshe.com/1DF43E

代码如下:

import toast from 'toast'
export default {
  created() {
    this.init()
  },
  methods: {
    // 获取微信scheme地址,并且主动跳转一次
    init() {
      this.$axios.post(`https://xxx/你们的接口地址/user/device/scheme`, this.$route.query).then(res => {
        if (res.success) {
          window.location.href = res.data
        } else {
          toast(res.msg)
        }
      }).catch(() => {
        toast('服务器错误,请稍后重试')
      })
    }
  }
}


原理:通过地址栏配置需要跳转的参数,h5页面拿到参数后通过接口转换为weixin://xxxx 开头的scheme协议地址,并且主动location.href一次。这样能保证用户每次打开都是新的scheme地址,针对一天50w数量上限的问题,可尝试同一个用户在固定时间内相同的参数,返回相同的scheme地址。

以上限制只存在于除微信外的外部浏览器,微信容器里没有以上的限制


2023年12月18日后方案:

官方公告如下:

https://developers.weixin.qq.com/community/develop/doc/00024e32cbc36055c0c0a34b066401 ,没有外部浏览器、微信环境的限制,可以被多人打开。

使用方式通过明文拼接:

weixin://dl/business/?appid=*APPID*&path=*PATH*&query=*QUERY*&env_version=*ENV_VERSION*

示例:

// query需要encode编码,ENV_VERSION为控制打开开发版、体验版、线上版本
weixin://dl/business/?appid=wxa7b0b022472e55e6&path=pages/partdetails/partdetails&query=partJobId%3D123456


通过明文 URL Scheme 拉起的小程序(页面)必须要提前在「小程序管理后台 -> 设置 -> 隐私与安全 -> 明文 scheme 拉起此小程序」中进行声明;

  • 小程序:配置能够通过明文 scheme 进入的小程序页面

这一点很烦很烦,希望能支持下 默认可打开所有的,不然每次都得去配置。


最后一次编辑于  08-07  
点赞 25
收藏
评论

25 个评论

  • 李十九
    李十九
    2022-09-15

    你好,请问微信外环境可以打开第三方小程序吗?

    2022-09-15
    赞同
    回复 2
    • 李十九
      李十九
      2022-09-15回复TNT
      appSecret和第三方小程序接口都不会提供,除了这两种方式还有其他的么?
      2022-09-15
      回复
    • TNT
      TNT
      09-04回复李十九
      现在支持明文形式
      09-04
      回复
  • Mr.Z
    Mr.Z
    2022-08-29

    您好,想问一下,如果要在 A公司的APP中嵌入B公司的H5,打开H5,点击跳转到C公司的小程序,这个只靠B公司操作是否能实现?您有类似的经验么?求解

    2022-08-29
    赞同
    回复
  • 七月旅人
    七月旅人
    2022-06-27

    4.11后如此完整的解决方案,快赞👍

    2022-06-27
    赞同
    回复
  • 2022-04-16

    云端生成scheme后直接跳转,就不会过期了~一天可以跳50W次,够用了~

    2022-04-16
    赞同
    回复
  • ᰔᩚ.༨ꫛꪝᝰ෴程 ๑҉ꦿ
    ᰔᩚ.༨ꫛꪝᝰ෴程 ๑҉ꦿ
    2022-03-29

    微信内部唤起小程序

    1、引入微信jssdk1.6

    2、微信初始化调用微信config

    3、使用wx-open-launch-weapp标签

    4、结果:按钮出不来。。

    2022-03-29
    赞同
    回复 7
    查看更多(2)
  • 黄锦程
    黄锦程
    发表于移动端
    2022-03-09
    呵呵
    2022-03-09
    赞同
    回复
  • 何金
    何金
    2022-01-05

    请问一下 ,第一种方式 确定在微信浏览器打不开吗? 为什么我的只能在微信浏览器打开?

    2022-01-05
    赞同
    回复 1
    • TNT
      TNT
      2022-01-05
      第一种方式可以了。微信更新了。之前打开提示参数错误。
      2022-01-05
      1
      回复
  • 坤坤坤坤坤
    坤坤坤坤坤
    2021-10-27

    你这个小程序确实可以用,我是公众号认证了,域名也加了,但是opentag死活不出来,一直显示空,支付功能jsspi都调用成功了,openTagList死活为空,不知道还有没有其他的办法了

    2021-10-27
    赞同
    回复 1
    • TNT
      TNT
      2021-10-27
      代码贴下。顺便贴个可访问的链接
      2021-10-27
      回复
  • 遥望sola
    遥望sola
    2021-09-09

    你好,请问我这边是企业号能调用开放标签吗,企业号的话config里的appId会和服务号有所不同

    2021-09-09
    赞同
    回复 4
    • TNT
      TNT
      2021-09-09
      企业号是指?企业的服务号?还是企业微信?
      2021-09-09
      回复
    • 晨曦
      晨曦
      2022-03-25回复TNT
      企业微信,可以使用开放标签吗
      2022-03-25
      回复
    • TNT
      TNT
      2022-03-28回复晨曦
      不行。
      2022-03-28
      回复
    • TNT
      TNT
      2022-03-28回复晨曦
      新做了个页面 放到微信可以。企业微信不显示 按钮 https://m.qtshe.com/app/spermDonation
      2022-03-28
      回复
  • 王妙端
    王妙端
    2021-09-08
    1. 必须是已认证的服务号
    2. 必须是已配置了js安全域名
    3. 开发的功能需要部署到该域名上访问,边写边调试是不行的、
    4. openTagList需存在需要使用的开放标签。

    以上添加都符合了 但是就是按钮还不显示

    访问地址:https://m.zbjsaas.com/testwc



    2021-09-08
    赞同
    回复 4
    • TNT
      TNT
      2021-09-08
      把debug打开。是不是签名错误了
      2021-09-08
      回复
    • 王妙端
      王妙端
      2021-09-08回复TNT
      对  要怎么改呢这个 不是非空即可吗
      2021-09-08
      回复
    • TNT
      TNT
      2021-09-08回复王妙端
      = =签名错误 你可以百度下 按步骤配置。跟后端调通。不调通是不会显示按钮的
      2021-09-08
      回复
    • 王妙端
      王妙端
      2021-09-08回复TNT
      好的 谢谢
      2021-09-08
      回复

正在加载...

登录 后发表内容