首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >喜大普奔,微信终于支持外网打开小程序啦!

喜大普奔,微信终于支持外网打开小程序啦!

作者头像
胡哥有话说
发布2021-02-19 10:51:14
1.3K0
发布2021-02-19 10:51:14
举报
文章被收录于专栏:胡哥有话说胡哥有话说

前言

千呼万唤始出来,微信小程序终于支持以URL Scheme的形式从外部唤起了。

long long ago~ 我们只能在微信内的网页中使用微信开发标签-小程序跳转按钮 <wx-open-launch-weapp>打开小程序,只有这样一种单一的场景。

而在实际的业务中,我们希望在给用户发送的营销短信、邮件或其他渠道如APP打开小程序,以快速获取用户流量,完成引流、导购等目的。

他来啦,他来啦,微信小程序悄咪咪的上线了新功能:支持URL Scheme打开小程序了。

新品上线

URL Scheme打开小程序新品上线,速来尝鲜。

可以随着胡哥的角度为你一一阐述、总结分析,也可以直接点击官方文档传送门查看官方文档呦~

我们首先来看下目前微信官方提供的两种打开微信小程序的方式以及相关适用场景。

打开方式

适用场景

场景值

使用方式

备注

URL Scheme

短信、邮件、微信外网页打开小程序

1065

location.href = 'weixin://dl/business/?t= *TICKET*'

TICKET由服务端接口返回

<wx-open-launch-weapp>

微信内网页

1167

页面配置<wx-open-launch-weapp>标签

需配置JS接口域名或云开发静态网站托管绑定的域名下网页

一定要注意区分两种方式的适用场景:URL scheme是适用于微信外网页,<wx-open-launch-weapp>是适用于微信内的。

小程序URL Scheme的获取

小程序的URL Scheme的结构为 weixin://dl/business/?t= *TICKET*,其中TICKET由服务端接口返回的。服务端接口区分两种形式:HTTPS调用云开发调用

一、HTTPS调用

获取ACCESS_TOKEN

请求地址:

GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

对应的APPID和APPSECRET换成自己对应的小程序即可。

返回的数据结构如下:

{
 "access_token": "ACCESS_TOKEN",
 "expires_in": 7200
}

获取URL Scheme

请求地址:

POST https://api.weixin.qq.com/wxa/generatescheme?access_token=ACCESS_TOKEN

请求参数:

属性

类型

默认值

必填

说明

access_token

string

接口调用凭证

jump_wxa

Object

跳转到的目标小程序信息。

is_expire

boolean

false

生成的scheme码类型,到期失效:true,永久有效:false。

expire_time

number

到期失效的scheme码的失效时间,为Unix时间戳。生成的到期失效scheme码在该时间前有效。最长有效期为1年。生成到期失效的scheme时必填。

jump_wxa 的结构

属性

类型

默认值

必填

说明

path

string

通过scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query。path为空时会跳转小程序主页。

query

string

通过scheme码进入小程序时的query,最大128个字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~

请求示例:

{
 "jump_wxa": {
  "path": "/pages/index/index",
  query": ""
 },
 "is_expire": true,
 "expire_time": 1606737600
}

返回结果:

{
 "errcode": 0,
 "errmsg": "ok",
 "openlink": Scheme,
}

openlink就是我们最终需要的URL Scheme啦~

二、云调用

云调用是小程序·云开发提供的在云函数中调用微信开放接口的能力,需要在云函数中通过 wx-server-sdk 使用

请求参数:

属性

类型

默认值

必填

说明

access_token

string

接口调用凭证

jump_wxa

Object

跳转到的目标小程序信息。

isExpire

boolean

false

生成的scheme码类型,到期失效:true,永久有效:false。

expireTime

number

到期失效的scheme码的失效时间,为Unix时间戳。生成的到期失效scheme码在该时间前有效。最长有效期为1年。生成到期失效的scheme时必填。

注意和HTTPS中参数名大小写不一致的情况

jump_wxa 的结构

属性

类型

默认值

必填

说明

path

string

通过scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query。path为空时会跳转小程序主页。

query

string

通过scheme码进入小程序时的query,最大128个字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~

请求示例:

const cloud = require('wx-server-sdk')
cloud.init({
  env: cloud.DYNAMIC_CURRENT_ENV,
})
exports.main = async (event, context) => {
  try {
    const result = await cloud.openapi.urlscheme.generate({
        jumpWxa: {
          path: '/pages/index/index',
          query: ''
        },
        isExpire: true,
        expireTime: 1606737600
      })
    return result
  } catch (err) {
    return err
  }
}

返回结果:

{
 "errcode": 0,
 "errmsg": "ok",
 "openlink": Scheme,
}

openlink就是我们最终需要的URL Scheme啦~

小程序URL Scheme的使用

小程序URL Scheme的结构是:weixin://dl/business/?t= *TICKET*,那我们拿到这个scheme之后如果使用呢。

IOS系统下是支持直接识别URL Scheme的,所以可以直接将URL Scheme发送到短信、邮件中,提供给用户使用。但是在Android系统不支持直接识别URL Scheme,用户无法Scheme正常打开小程序,所以需要开发者自行使用H5页面进行中转,再跳转使用Scheme方式打开微信小程序。

使用方式

备注

Android

location.href='weixin://dl/business/?t= *TICKET*'

只有一种方式

IOS

直接识别URL Scheme 或使用location.href方式

两种方式

But, 我们要注意一个问题,当我们进行短信触达时,无法确定用户所使用的的手机设备是IOS还是Android

So, 我们从实际的业务触发,都需要一个H5页面进行中转处理。

小程序唤起业务流程图

当当当,综合两种打开小程序的方式(URL Scheme和 <wx-open-launch-weapp>),完整版的小程序唤起业务流程图来啦~

小程序唤起业务流程图

后记

以上就是胡哥今天给大家分享的内容,喜欢的小伙伴记得点赞收藏呀,关注胡哥有话说,学习前端不迷路,欢迎多多留言交流...

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-02-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 胡哥有话说 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 新品上线
  • 小程序URL Scheme的获取
    • 一、HTTPS调用
    • 小程序URL Scheme的使用
    • 小程序唤起业务流程图
    • 后记
    相关产品与服务
    云开发 CloudBase
    云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档