小程序生成URL Link,获取query参数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小程序生成URL Link,获取query参数相关的知识,希望对你有一定的参考价值。

参考技术A 注: 获取 URL Link前需要先获取access_token。通过 URL Link 进入的小程序页面路径,必须是已经发布的小程序存在的页面。

urllink.generate

接口返回的url_link即生成的小程序 URL Link,可以在短信、邮件、网页、微信内等拉起小程序的业务场景。

在onLoad 中获取的方法

uniapp 前端获取微信小程序 URL Link (HTTPS调用)

前端基于 uniapp 获取微信小程序 URL Link 短链,适用于短信、邮件、网页、微信内等拉起小程序的业务场景。目前仅针对国内非个人主体的小程序开放。

前言:微信小程序此前可以在小程序管理后台-工具 中直接快捷生成小程序指定页面的 https 短链,后微信官方更新后弃用了该方式采用调用官方获取小程序短链的API获取且自 2022 年 4 月 11 日起,URL Link有效期最长 30 天,不再支持永久有效的URL Link、不再区分短期有效URL Link与长期有效URL Link。详情见官方文档

注:微信官方文档提醒获取小程序 URL Link 的接口应该在服务器端调用,本文主要是记录前端自行生成小程序指定页面 https 短链的方法。(微信官方文档-获取URL Link:urllink.generate )

本文示例使用 HTTPS 调用方式,并封装了将小程序指定页面直接转换为 https 短链的方法。

准备:首先你需要准备好该小程序的 AppID(小程序ID) 和 AppSecret(小程序密钥) 。这是生成 access_token 所必须的。(获取路径:登录微信小程序管理后台-开发管理-开发设置)

已将获取小程序指定页面 https 短链的核心业务封装为 getAppLink() 方法,可直接复制使用,注意该方法发起网络请求的方式是 uni.request() ,该方法中的 appidsecret 需填充你小程序的相关数据。核心代码如下:

getAppLink(params) 
        // AppID(小程序ID)
        const appid = ''
        // AppSecret(小程序密钥)
        const secret = ''
        // 先发起请求获取凭证
        uni.request(
          url: `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=$appid&secret=$secret`,
          method: 'GET',
          success(res) 
            console.log('获取凭证', res);
            // 再发起请求获取url
            uni.request(
              url: `https://api.weixin.qq.com/wxa/generate_urllink?access_token=$res.data.access_token`,
              method: 'POST',
              data: 
                ...params
              ,
              success(result) 
                console.log('生成网址:', result.data);
                return result.data.url_link
              
            )
          
        )
      ,

调用示例:

        let params = 
          // path:要跳转到的小程序的目标页面纯路径(不要拼接参数)
          // 注意:如果该链接要打开的版本是正式版,则这个path一定要已经发布到了正式版,不然无法访问到该页面则链接无法生成成功
          path: '/pages/index',
          query: "id=1&type=2", // 短链的入参
          env_version: "release", // 正式版
          expire_type: 1, 
          expire_interval: 30,
        
        const url = await this.getAppLink(params)
        console.log('返回的url:', url);

注:调用时需要传递一个 params 的参数对象,该对象涉及参数见下图: 

:上图出处-微信官方文档 

上图参数说明见-小程序链接生成与使用规则调整公告

生成的链接形如:https://wxaurl.cn/pFawq35qbfd

生成短链成功后可使用 微信开发者工具 编译查看效果

 最后温馨提示:前端使用此方法生成所需的 https 短链后如果要将测试版提交审核,请先将 getAppLink() 方法中使用到的小程序的 AppID(小程序ID) 和 AppSecret(小程序密钥) 删除/清空(特别是 AppSecret),否则它会影响到代码审核,会告知存在安全风险无法审核通过!!!

以上是关于小程序生成URL Link,获取query参数的主要内容,如果未能解决你的问题,请参考以下文章

微信小程序开发,怎么获取小程序场景值?

微信小程序开发 怎么获取小程序场景值

uniapp 前端获取微信小程序 URL Link (HTTPS调用)

微信小程序分享小程序码的生成(带参数)以及参数的获取

小程序页面传递数据 、传递数组对象 小程序传值

vue中获取url参数