活动页中打开APP、扫码下载APP方案总结

最近做活动,需要用到在H5中打开/下载APP,PC端扫码下载APP相关业务,看似很小的一个功能,却蕴藏很大玄机。主要的难点在于在微信中唤醒APP,参考了很多产品的实现方式,对唱吧、今日头条、SegmentFault等平台颇为满意。最终我们团队,也实现了想要的功能。

功能描述

①Android端 微信中,依托应用宝实现打开、下载逻辑;
浏览器中,本地没有APP,跳到指定下载页,有APP可以唤醒APP并打开指定活动页。
②IOS端 微信中,本地没有APP,依托应用宝进行下载,本地有APP,则可以在微信中唤醒APP,并且在APP中打开该活动页。
浏览器中,本地没有APP,跳iTunes下载,有APP,唤醒。


一、方案流程

难度 使用技术 能否跳转到指定页面
Android/微信 简单 应用宝链接
Android/浏览器 简单 Schema
Ios/微信 复杂 Universal Links
Ios/浏览器 复杂 Universal Links

二、针对以上方案ios端的配置工作:

1、需要一台https服务器,且在微信端进行过安全认证,否则在安卓微信端容易导致页面跳转失败!!!目前使用的shui5的服务器在微信端没经过认证,所以实现逻辑不太一样

①apple-app-site-association文件
注意这个文件必须没有后缀名,文件名必须为apple-app-site-association!!!,请放置在https服务器的根目录,eg:(https://171edu.com/apple-app-site-association);
②将download.html页面也放在之前的https服务器下 eg:(https://171edu.com/download.html)

{
    "applinks": {
        "apps": [],
        "details": [
            {
                "appID": "add your id",
                "paths": [ "*" ]
            },
            {
                "appID": "add your id",
                "paths": [ "*" ]
            }
        ]
    }
}

③之前的服务器(https://171edu.com) 要在ios的app中进行备案,当app拦截到这个domain时,会查看本地是否有app,如果有打开,并根据url后面的传参,打开相应的活动页面,如果本地没有app,则跳转至download页面,进行逻辑判断。

2、打开app在ios端的实现逻辑
iOS/微信
界面流程: 1. 扫描打开H5页面->点击打开应用按钮->打开一张不同域的网页,如存在则打开App/如不存在则打开App Store
实现流程: 1. 点击按钮 - >判断为微信/ios ->重定向到不同域的网页

iOS/浏览器
界面流程: 1. 打开H5页面->点击打开应用按钮->打开一张不同域的网页,如存在则打开App/如不存在则打开App Store
实现流程: 1. 点击按钮 - >判断为微信/ios ->重定向到不同域的网页

Itunes下载地址:https://itunes.apple.com/cn/app/id1127148565

三、Android实现

Android/微信
界面流程:1.打开H5页面->点击打开应用按钮->载入应用宝链接(移动团队提供)->逻辑交由应用宝管理
实现流程: 1.点击按钮->判断是微信端/android->重定向当前页面至应用宝页面(移动团队提供)

Android/浏览器
界面流程: 1. 打开浏览器输入地址(或微信浏览器中以外部浏览器打开)->点击打开应用按钮->如已存在则打开程序/未存在开始下载
实现流程: 1. 点击按钮 ->判断是否浏览器端/android ->重定向android规定Schema字符串->同时定时器重定向到android下载路径

  1. 应用宝地址:
    http://a.app.qq.com/o/simple.jsp?pkgname=com.winwin.tax
  2. Schema规则:
    winwin://?type=activity&url=
    http://promotion.171edu.com/swpx/index.html

四、相关页面代码

//①download.html

<script>
window.onload = function() {
 var env = {
 agent: window.navigator.userAgent.toLowerCase(),
 downURL: 'http://appdownload.17win.com/17win150.apk',
 activityURL: 'winwin://?type=activity&url=http://promotion.171edu.com/swpx/index.html?edu',
 yybaoURL: 'http://a.app.qq.com/o/simple.jsp?pkgname=com.winwin.tax',
 iosURL: 'https://itunes.apple.com/cn/app/id1127148565',
 eduURL: 'https://shui5.servyou.com.cn/download.html?utm_campaign=xueyuan&utm_medium=app&utm_source=ewm',(app的新版本此处链接改为https://171edu.com/...)

 isWechat: function () {
     return this.agent.match(/MicroMessenger/i) == 'micromessenger';
 },
 isAndroid: function () {
     return this.agent.match(/android/i) == 'android';
 },
 isIphone: function () {
     return this.agent.match(/iphone/i) == 'iphone';
 },
 init: function () {
     if (env.isWechat()) {
    //微信端都跳转到应用宝
     window.location.href = env.yybaoURL;
     } else {
       if (env.isAndroid()) {
         // 非微信安卓端实现思路
         //首先唤醒本地app,如果本地有app,打开app,清除定时器,
         //如果不存在app,则跳转到apk下载页面,下载app
         timer = setTimeout(function () {
         window.location.href = env.downURL;
         }, 800);
         window.location.href = env.activityURL;
         window.onpagehide = function () {
         clearTimeout(timer);
         }
         } else {
         window.location.href = env.iosURL;
         }
       }
     }
   };
   env.init();
}
</script>

//②app.html

<script>
 var env = {
 agent: window.navigator.userAgent.toLowerCase(),
 downURL: 'http://appdownload.17win.com/17win150.apk',
 activityURL: 'winwin://?type=activity&url=http://promotion.171edu.com/swpx/index.html?edu',
 yybaoURL: 'http://a.app.qq.com/o/simple.jsp?pkgname=com.winwin.tax',
 // eduURL: 'https://171edu.com/download.html',
 eduURL: 'https://shui5.servyou.com.cn/download.html?type=activity&url=http://promotion.171edu.com/swpx/index.html&utm_campaign=xueyuan&utm_medium=app&utm_source=ewm',
 iosActivityURL: 'https://shui5.servyou.com.cn/download.html?type=activity&url=http://promotion.171edu.com/swpx/index.html',

 isWechat: function(){
     return this.agent.match(/MicroMessenger/i) == 'micromessenger';
 },
 isAndroid: function(){
     return this.agent.match(/android/i) == 'android';
 },
 isIphone: function(){
     return this.agent.match(/iphone/i) == 'iphone';
   }
 };
 window.onload = function() {
     var btn = document.getElementById('btn');
     btn.click();
 };

 function goto () {
     window.location.href = 'https://shui5.servyou.com.cn/download.html?utm_campaign=xueyuan&utm_medium=app&utm_source=ewm';
 }
</script>
<button style="opacity: 0;" id="btn" onclick=goto()></button>

//③活动页面中打开app相关js
////env.js

var env = {
 agent: window.navigator.userAgent.toLowerCase(),
 downURL: 'http://appdownload.17win.com/',
 activityURL: 'winwin://?type=activity&url=http://promotion.171edu.com/swpx/index.html?edu',
 yybaoURL: 'http://a.app.qq.com/o/simple.jsp?pkgname=com.winwin.tax',
 eduURL: 'https://171edu.com/download.html?type=activity&url=http://promotion.171edu.com/swpx/index.html&utm_campaign=xueyuan&utm_medium=app&utm_source=ewm',
 shui5URL: 'https://shui5.servyou.com.cn/download.html?type=activity&url=http://promotion.171edu.com/swpx/index.html&utm_campaign=xueyuan&utm_medium=app&utm_source=ewm',
 iosActivityURL: 'https://shui5.servyou.com.cn/download.html?type=activity&url=http://promotion.171edu.com/swpx/index.html',

 isWechat: function(){
     return this.agent.match(/MicroMessenger/i) == 'micromessenger';
 },
 isAndroid: function(){
     return this.agent.match(/android/i) == 'android';
 },
 isIphone: function(){
     return this.agent.match(/iphone/i) == 'iphone';
   }
};
;$(function() {
 $('.btn-app').bind('click', function() {
//现在实现逻辑
 if(env.isWechat() && env.isAndroid()){
     window.location.href = env.yybaoURL;
 }else {
     window.location.href = env.shui5URL;
 }
 });
//以后用171edu服务器,直接用下面的
//window.location.href = env.eduURL;
});

五、扫码下载实现逻辑

二维码为app.html,该页面主要是模拟触发点击按钮事件,进行跳转到download.html,之后进行下载业务处理

本人的第一篇博客,感谢您阅读到了最后,文中如果有不足之处,还请批评指正。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,099评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,828评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,540评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,848评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,971评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,132评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,193评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,934评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,376评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,687评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,846评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,537评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,175评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,887评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,134评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,674评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,741评论 2 351

推荐阅读更多精彩内容