前言

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

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

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

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

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

新品上线

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

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

小程序URL Scheme的获取

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

一、HTTPS调用

  1. 获取ACCESS_TOKEN

    请求地址:

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

    返回的数据结构如下:

    {
    	"access_token": "ACCESS_TOKEN",
    	"expires_in": 7200
    }
    
  2. 获取URL Scheme

    请求地址:

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

    请求参数:

    jump_wxa 的结构

    请求示例:

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

    返回结果:

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

二、云调用

请求参数:

jump_wxa 的结构

请求示例:

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,
}

小程序URL Scheme的使用

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

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

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

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

小程序唤起业务流程图

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

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

后记

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

02-03 21:40