为了微信小程序的推广,微信提供了多种小程序入口方式,比如在公众号中可以将已经关联过的小程序的页面放置到自定义菜单中,用户单击后就可以打开小程序的相关页面;或者是给用户发送公众号模板消息,用户点击收到的模板消息进入小程序。不过这些方式都需要微信客户端的支持,有些情况下您可能希望在微信客户端之外的APP中打开小程序,比如您可能通过短信或者邮件给用户发送营销通知,并希望用户在短信或邮件APP中打开小程序,以快速获取用户流量,完成引流、导购等目的。对于这种诉求,微信也给予了支持,下面介绍如何生成URL Scheme以及通过URL Scheme打开小程序的方法。

9.3.1生成小程序URL Scheme码

小程序URL Scheme码,用于短信、邮件、外部网页、微信内等方式拉起小程序的。通过服务端接口urlscheme.generate可以为小程序的任意页面生成小程序URL Scheme码。生成的URL Scheme如下所示:
weixin://dl/business/?t= *TICKET*
接口地址
api.weixin.qq.com/wxa/generatescheme?access_token=[xxx]

请求参数:

  • access_toke:接口调用凭证
  • jump_wxa:跳转到的目标小程序信息。
  • is_expire:生成的URL Scheme码类型,到期失效:true,永久有效:false。
  • expire_time:URL Scheme码的失效时间,为Unix时间戳。生成的URL Scheme码在该时间前有效。最长有效期为1年。
  • path:通过URL Scheme码进入的小程序页面路径,必须是已经发布的小程序存在的页面,不可携带query。path为空时会跳转小程序主页。
  • query:通过URL Scheme码进入小程序时的query,最大1024个字符,只支持数字,大小写英文以及部分特殊字符.

返回值

返回小程序URL Scheme码

示例代码

type WxJumpWxa  struct {Path  string     `json:"path"`//通过scheme码进入的小程序页面路径Query string     `json:"query"` //通过scheme码进入小程序时的query
}
type WxUrlSchemeReq struct {Jump_wxa      WxJumpWxa `json:"jump_wxa"`//跳转到的目标小程序信息Is_expire     bool      `json:"is_expire"` //到期失效:true,永久有效:falseExpire_type    int64         `json:"expire_type"`//失效时间:0,失效间隔天数:1Expire_time    int64         `json:"expire_time"`//到期失效的 scheme 码的失效时间,为 Unix 时间戳Expire_interval    int64     `json:"expire_interval"`//到期失效的 scheme 码的失效间隔天数
}
type WxUrlSchemeRet struct {ErrCode       int64         `json:"errcode"`ErrMsg        string        `json:"errmsg"`Openlink      string        `json:"openlink"`
}
//生成页面Scheme码
func HandlerUrlScheme(w http.ResponseWriter, r *http.Request) {//page路径必须为已发布的小程序页面路径page := r.FormValue("page");//通过scheme码进入小程序时的queryquery := r.FormValue("query");var req  WxUrlSchemeReqreq.Is_expire = truereq.Expire_type = 0req.Expire_time = time.Now().AddDate(0, 0, 30).Unix()req.Jump_wxa.Path = pagereq.Jump_wxa.Query = queryparamstr, _ := json.Marshal(req)fmt.Println(string(paramstr))wx_addr := "https://api.weixin.qq.com/wxa/generatescheme"wx_addr += "?access_token=" + GetWxToken()fmt.Println(wx_addr)res, err := http.Post(wx_addr, "charset=UTF-8", bytes.NewBuffer(paramstr))if err != nil {fmt.Println(err)http.Error(w, "微信请求错误", http.StatusInternalServerError)return}raw, err := ioutil.ReadAll(res.Body)res.Body.Close()if err != nil {fmt.Println(err)http.Error(w, "微信返回错误", http.StatusInternalServerError)return}fmt.Println(string(raw))var ret WxUrlSchemeReterr = json.Unmarshal(raw, &ret)if err != nil {fmt.Println(err)http.Error(w, "微信返回错误", http.StatusInternalServerError)return}w.Write([]byte(ret.Openlink))
}

9.3.2小程序URL Scheme码的使用

urlscheme.generate生成的URL Scheme如下所示:
weixin://dl/business/?t= *TICKET*
IOS系统支持识别URL Scheme,可在短信等应用场景中直接通过URL Scheme跳转小程序。Android系统不支持直接识别URL Scheme,用户无法通过URL Scheme正常打开小程序。开发者需要使用H5页面中转,再跳转到URL Scheme来打开小程序,跳转连接的格式如下所示:
location.href = 'weixin://dl/business/?t= *TICKET*'
但是当我们短信或邮件中打开跳转链接时,是无法确定用户所使用的的手机设备是IOS还是Android,因此我们从实际的业务触发,都需要一个H5页面进行中转处理。
说明:

  • 通过URL Scheme打开小程序的场景值为 1065。
  • 微信内的网页如需打开小程序请使用微信开放标签-小程序跳转按钮,无公众号也可以直接使用小程序身份开发网页并免鉴权跳转小程序。符合开放范围的小程序可以下发支持打开小程序的短信。
  • 只能生成已发布的小程序的URL Scheme。
  • 通过URL Scheme跳转到微信时,会触发系统弹框询问,若用户选择不跳转,则无法打开小程序。请开发者妥善处理用户选择不跳转的场景。

微信小程序开发实战9_3 小程序URL Scheme相关推荐

  1. 微信小程序开发实战9_2 小程序页面转发

    小程序页面转发是小程序分享的一个重要方式,在设计小程序应用时就需要考虑那些页面需要实现转发功能,以及页面的转发参数.本节介绍如何进行小程序页面的分享,并介绍如何获取小程序卡片的分享票据. 9.2.1小 ...

  2. 微信小程序开发实战8_2 小程序客服消息的发送

    8.3 上传素材 开发者发送给用户的消息中图片消息.小程序卡片消息包含有媒体ID,媒体ID是开发者上传媒体文件(图片文件.视频文件等)到微信服务器的后由微信服务器返回的一个媒体编码.上传媒体文件的接口 ...

  3. 微信小程序开发实战10_1 小程序支付业务介绍

    移动支付已成大多数消费者日常使用的支付方式之一.移动支付拥有操作简单方便.无需带现金或银行卡,不用找零,目前超过四分之三的用户都在使用移动支付.小程序应用作为一个广泛使用的移动应用,自然也不会放弃移动 ...

  4. 微信小程序开发实战8_1 小程序客服消息的接收

    为丰富小程序的服务能力,提高服务质量,微信为小程序提供客服消息的功能.小程序用户可以使用客服消息与小程序服务提供方进行沟通. 客服消息会话入口 小程序内:开发者在小程序内添加客服消息按钮组件,用户可在 ...

  5. 微信小程序|开发实战篇之二

    开发实战篇之二 前言 1.零碎知识点和优化点 1.1 ES6模板字符串 1.2 ES6扩展运算符 1.3 独立更新like组件状态 1.4 自定义组件支持hidden 2.音乐music组件开发 2. ...

  6. 视频教程-微信小程序开发实战之番茄时钟开发-微信开发

    微信小程序开发实战之番茄时钟开发 4年web前后端开发经验,熟悉PHP,Python后端技术,熟悉基于Lnmp环境的项目开发和部署,擅长Yii,ThinkPHP,CI,Django,Flask等国内外 ...

  7. 微信小程序开发实战(9):单行输入和多行输入组件

    -----------支持作者请转发本文----------- 1.  单行输入组件(input) input组件用于录入单行文本,尽管input的基本功能是文本录入,但该组件的属性还是比较多的,也比 ...

  8. JEECG社区微信小程序开发实战-张代浩-专题视频课程

    JEECG社区微信小程序开发实战-511人已学习 课程介绍         微信小程序开发培训,包含环境搭建.实例讲解.对接支付功能等课题. 课程收益     微信小程序开发培训,包含环境搭建.实例讲 ...

  9. 《微信小程序开发实战》课后题

    黑马程序员版<微信小程序开发实战> 第一章 填空题 1.微信小程序可以通过________方式打开. 答案:扫描二维码 2.微信开发者工具中的上传是指将代码上传到________. 答案: ...

最新文章

  1. 官方 | TensorFlow 2.0分布式训练教程
  2. Python参考书籍
  3. 解析Linux 多应用程序docker自动部署脚本
  4. 机器学习资源-Harvard Ph.D Sam维护
  5. node --- 模拟事件的异步
  6. Android之DrawText详解
  7. 面向对象(特点)、局部变量与全局变量的区别、匿名对象、构造函数、
  8. java上传kafka的方法_哪种方法是将所有数据从Kafka主题复制到接收器(文件或Hive表)的最佳方法?...
  9. Android Studio(7)---查找例子
  10. iOS 状态栏 修改为白色字体的步骤
  11. Windows 上安装 Scala
  12. OVM 免费虚拟化软件迭代时间调整,提高产品稳定性!
  13. DevExpress WinForms v20.2版本亮点放送——PDF Viewer功能加强
  14. Python爬取小说网站页面制作电子书
  15. dnf强化卷代码_dnf强化卷叫什么名字?
  16. PLC是怎么工作的?工作原理是什么?
  17. 【区块链】——区块链与5G技术的结合
  18. 硬盘分区无法打开,提示“文件或目录损坏且无法读取”
  19. C语言 整数形式输出
  20. Matlab Babble噪声

热门文章

  1. 凹入表示法(C语言版)
  2. PID控制算法原理通俗讲解
  3. tplink控制上网设备_TP-LINK无线路由器怎么设置限制别人wifi网速
  4. 思维模型 塔西陀陷阱
  5. 人脸旋转对齐(opencv-python)
  6. 声音识别动画(下)-----线形(曲线)声音识别动画
  7. 20189220 余超《Linux内核原理与分析》第六周作业
  8. CreateFontIndirect
  9. Windows 之 win SMB(smb) 功能的开启设置和使用的简单说明
  10. adb连接各种模拟器