获取加密URLLink

获取加密URLLink

调试工具

接口应在服务器端调用,详细说明参见服务端API

本接口支持云调用。需开发者工具版本 >= 1.02.1904090(最新稳定版下载),wx-server-sdk >= 0.4.0

接口说明

接口英文名

generateUrlLink

功能描述

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

注意事项

调用上限

  • 生成端:每天生成 URL Scheme(加密 明文) 和 URL Link 的总数量上限为50万
  • 打开端:每天通过 URL Scheme(加密 明文) 和 URL Link 打开小程序的总次数上限为300万
  • 自 2023 年 12 月 19 日起,取消 URL Link 一人一链的限制,支持同一条连接被多名用户访问。详细调整说明可见《URL Scheme 和 URL Link优化公告》

返回值说明

  • 如果调用成功,会直接返回生成的小程序 URL Link。如果请求失败,会返回 JSON 格式的数据。

其他注意事项

  • 加密 URL Link 支持开发者自行在链接后面拼接 query 参数,详见获取 URL Link
  • 只能生成已发布的小程序的 URL Link。
  • 在微信内或者安卓手机打开 URL Link 时,默认会先跳转官方 H5 中间页,如果需要定制 H5 内容,可以使用云开发静态网站。

调用方式

HTTPS 调用

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

云调用

  • 出入参和HTTPS调用相同,调用方式可查看云调用说明文档
  • 接口方法为: openapi.urllink.generate

第三方调用

  • 调用方式以及出入参和HTTPS相同,仅是调用的token不同
  • 该接口所属的权限集id为:88、115
  • 服务商获得其中之一权限集授权后,可通过使用authorizer_access_token代商家进行调用

请求参数

属性 类型 必填 说明
access_token string 接口调用凭证,该参数为 URL 参数,非 Body 参数。使用getAccessToken 或者 authorizer_access_token
path string 通过 URL Link 进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带 query 。path 为空时会跳转小程序主页
query string 通过 URL Link 进入小程序时的query,最大1024个字符,只支持数字,大小写英文以及部分特殊字符:!#$&'()*+,/:;=?@-._~%
expire_type number 默认值0.小程序 URL Link 失效类型,失效时间:0,失效间隔天数:1
expire_time number 到期失效的 URL Link 的失效时间,为 Unix 时间戳。生成的到期失效 URL Link 在该时间前有效。最长有效期为30天。expire_type 为 0 必填
expire_interval number 到期失效的URL Link的失效间隔天数。生成的到期失效URL Link在该间隔时间到达前有效。最长间隔天数为30天。expire_type 为 1 必填
cloud_base object 云开发静态网站自定义 H5 配置参数,可配置中转的云开发 H5 页面。不填默认用官方 H5 页面
属性类型必填说明envstring是云开发环境domainstring否静态网站自定义域名,不填则使用默认域名pathstring否云开发静态网站 H5 页面路径,不可携带 queryquerystring否云开发静态网站 H5 页面 query 参数,最大 1024 个字符,只支持数字,大小写英文以及部分特殊字符:`!#$&'()*+,/:;=?@-._~%``resource_appidstring否第三方批量代云开发时必填,表示创建该 env 的 appid (小程序/第三方平台)
env_version string 默认值"release"。要打开的小程序版本。正式版为 "release",体验版为"trial",开发版为"develop",仅在微信外打开时生效。

返回参数

属性 类型 说明
errcode number 错误码
errmsg string 错误信息
url_link string 生成的小程序 URL Link

调用示例

示例说明: HTTPS请求

请求数据示例

{
    "path": "/pages/publishHomework/publishHomework",
    "query": "",
    "expire_type":1,
    "expire_interval":1,
    "env_version": "release",
    "cloud_base":
    {
        "env": "xxx",
        "domain": "xxx.xx",
        "path": "/jump-wxa.html",
        "query": "a=1&b=2"
    }
} 

返回数据示例

{
 "errcode": 0,
 "errmsg": "ok",
 "url_link": "URL Link"
} 

示例说明: 云函数调用

请求数据示例

const cloud = require('wx-server-sdk')
cloud.init({
  env: cloud.DYNAMIC_CURRENT_ENV,
})
exports.main = async (event, context) => {
  try {
    const result = await cloud.openapi.urllink.generate({
        "path": '/pages/publishHomework/publishHomework',
        "query": '',
        "isExpire": true,
        "expireType": 1,
        "expireInterval": 1,
        "envVersion": 'release',
        "cloudBase": {
          "env": 'xxx',
          "domain": 'xxx.xx',
          "path": '/jump-wxa.html',
          "query": 'a=1&b=2'
        }
      })
    return result
  } catch (err) {
    return err
  }
} 

返回数据示例

{
 "errCode": 0,
 "errMsg": "ok",
 "urlLink": "URL Link"
} 

错误码

错误码 错误描述 解决方案
-1 system error 系统繁忙,此时请开发者稍候再试
40001 invalid credential access_token isinvalid or not latest 获取 access_token 时 AppSecret 错误,或者 access_token 无效。请开发者认真比对 AppSecret 的正确性,或查看是否正在为恰当的公众号调用接口
40002 invalid grant_type 暂无生成权限(个人主体小程序无权限,或者NFC 能力的小程序未申请权限)
40013 invalid appid 生成权限被封禁
85079 miniprogram has no online release 小程序没有线上版本,即小程序尚未发布,不可进行该操作
40165 invalid weapp pagepath 参数path填写错误,更正后重试
40212 invalid query 参数query填写错误 ,query格式遵循URL标准,即k1=v1&k2=v2
85401 time limit between 1min and 30days 参数expire_time填写错误,时间间隔大于1分钟且小于30天,更正后重试
85402 invalid env_version 参数env_version填写错误,更正后重试
44990 reach max api second frequence limit 频率过快,超过100次/秒;降低调用频率
44993 reach max api day frequence limit 单天生成加密 URL Scheme+URL Link 数量超过上限50万
85406 daily visit limit URL Scheme(加密+明文)/加密 URL Link 单天累加访问次数超过上限
85088 未开通云开发 请先开通云开发
posted on 2025-01-14 08:26  AtlasLapetos  阅读(211)  评论(0)    收藏  举报