urlscheme.generate

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

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

获取小程序scheme码,适用于短信、邮件、外部网页等拉起小程序的业务场景。通过该接口,可以选择生成到期失效和永久有效的小程序码,目前仅针对国内非个人主体的小程序开放,详见获取URL scheme码

调用方式:

HTTPS 调用

请求地址

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

请求参数

属性类型默认值必填说明
access_tokenstring接口调用凭证
jump_wxaObject跳转到的目标小程序信息。
is_expirebooleanfalse生成的scheme码类型,到期失效:true,永久有效:false。
expire_timenumber到期失效的scheme码的失效时间,为Unix时间戳。生成的到期失效scheme码在该时间前有效。最长有效期为1年。生成到期失效的scheme时必填。

jump_wxa 的结构

属性类型默认值必填说明
pathstring通过scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query。path为空时会跳转小程序主页。
querystring通过scheme码进入小程序时的query,最大1024个字符,只支持数字,大小写英文以及部分特殊字符:!#$&’()*+,/:;=?@-._~

返回值

openlink

生成的小程序scheme码

异常返回

Object

JSON

属性类型说明
errcodenumber错误码
errmsgstring错误信息

errcode 的合法值

说明最低版本
40002暂无生成权限
40013生成权限被封禁
85079小程序未发布
40165参数path填写错误
40212参数query填写错误
85401参数expire_time填写错误,时间间隔大于1分钟且小于1年
44990生成Scheme频率过快(超过100次/秒)
85400长期有效Scheme达到生成上限10万
45009单天生成Scheme数量超过上限50万

返回值说明

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

示例

请求

  1. {
  2. "jump_wxa":
  3. {
  4. "path": "/pages/publishHomework/publishHomework",
  5. "query": ""
  6. },
  7. "is_expire":true,
  8. "expire_time":1606737600
  9. }

返回

  1. {
  2. "errcode": 0,
  3. "errmsg": "ok",
  4. "openlink": Scheme,
  5. }

云调用

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

接口方法

  1. openapi.urlscheme.generate

需在 config.json 中配置 urlscheme.generate API 的权限,详情

请求参数

属性类型默认值必填说明
jumpWxaObject跳转到的目标小程序信息。
isExpirebooleanfalse生成的scheme码类型,到期失效:true,永久有效:false。
expireTimenumber到期失效的scheme码的失效时间,为Unix时间戳。生成的到期失效scheme码在该时间前有效。最长有效期为1年。生成到期失效的scheme时必填。

jumpWxa 的结构

属性类型默认值必填说明
pathstring通过scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query。path为空时会跳转小程序主页。
querystring通过scheme码进入小程序时的query,最大1024个字符,只支持数字,大小写英文以及部分特殊字符:!#$&’()*+,/:;=?@-._~

返回值

openlink

生成的小程序scheme码

异常

Object

JSON

属性类型说明
errCodenumber错误码
errMsgstring错误信息

errCode 的合法值

说明最低版本

示例

请求

  1. const cloud = require('wx-server-sdk')
  2. cloud.init({
  3. env: cloud.DYNAMIC_CURRENT_ENV,
  4. })
  5. exports.main = async (event, context) => {
  6. try {
  7. const result = await cloud.openapi.urlscheme.generate({
  8. jumpWxa: {
  9. path: '/pages/publishHomework/publishHomework',
  10. query: ''
  11. },
  12. isExpire: true,
  13. expireTime: 1606737600
  14. })
  15. return result
  16. } catch (err) {
  17. return err
  18. }
  19. }

返回

  1. {
  2. "errcode": 0,
  3. "errmsg": "ok",
  4. "openlink": Scheme,
  5. }