Android DeepLink 深度链接技术实现

一、DeepLink 技术介绍

DeepLink,即为深度链接技术,主要应用场景是通过Web页面直接调用Android原生app,并且把需要的参数通过Uri的形式,直接传递给app,节省用户的注册成本。

DeepLink 通常运用于App社交分享、App广告引流、App裂变活动、Web to App、分享效果统计、沉默用户唤醒等场景,对广告引流、活动推广、新闻类、电商类、游戏类、视频直播类App的引流推广和转化都有着奇效。

常见使用场景如下:

  • 电商类:在分享商品链接中点击,进入 App 内对应店铺或购物页面
  • 资讯类:在分享新闻链接中点击,进入 App 内对应内容页面
  • 游戏类:在分享邀请组队的链接中点击,进入 App 内对应的游戏房间或战队队伍中
  • 广告:在社交平台点击相关广告,进入 App 内对应内容页面
  • 拉新活动:例如老带新邀请、福利抽奖等 H5 页面活动,参与者可以点击进入 App 内对应活动参与页面

App 间的自由跳转,解决的不仅仅是用户体验问题,更是拓展 App 的应用宽度问题,有了深度链接后,App 之间不再是独立的个体平台,开发者可以在移动端再现网页端的自由跳转,将广告、活动营销、裂变拉新、用户唤醒等业务结合其中,创造一个更加完整、精简的转化链,能给 App 的运营和推广带来更多想象空间。

二、Android DeepLink 技术实现

Android的DeepLink实现首先需要在Web页面调起Android App,这块的基础实现,我们在之前整理的 Android 从浏览器启动应用 里面已经讲述了。

这里我们再进行更多的扩展和说明。

移动端深度链接,本质上是使用URI的schema,移动操作系统提供解析schema的能力,判断schema属于哪个app,唤起并将参数传递给App。

URI实例:myapp://test/spec?param1=p1&param2=p2

其中需要注意的是:

  • App1必须支持,如微信屏蔽了很多schema,一般手机浏览器不会屏蔽shcema;
  • APP2必须支持,APP也需要开发,让系统知道其对应的schema,并解析参数定位到具体位置。

Android 深度链接唤起App顺序:

  1. 打开用户指定的首选APP(如果用户指定了URI对应的APP);
  2. 打开处理URI的唯一APP;
  3. 对话框中选择相应的APP(URI对应多个APP的情况)

如何进行URI Schema的配置,可以参照  Android 从浏览器启动应用即在Activity的配置文件中添加如下:

<intent-filter>
   <data android:scheme="***" /> /* URI Schema 在此进行配置 */
   <action android:name="android.intent.action.VIEW" />
   <category android:name="android.intent.category.DEFAULT" />
   <category android:name="android.intent.category.BROWSABLE" />
</intent-filter>

data可配置的内容如下:

<data
     android:scheme="xxxx"
     android:host="xxxx"
     android:port="xxxx"
     android:path="xxxx"
     android:pathPattern="xxxx"
     android:pathPrefix="xxxx"
     android:mimeType="xxxx"/>

这里我们解释一个每个字段所代表得意思:

  • scheme:协议类型,我们可以自定义,一般是项目或公司缩写,String
  • host:域名地址,String
  • port:端口,int。
  • path:访问的路径,String
  • pathPrefix:访问的路径的前缀,String
  • pathPattern:访问路径的匹配格式,相对于path和pathPrefix更为灵活,String
  • mimeType:资源类型,例如常见的:video/*, image/png, text/plain。

通过这几个配置项,我们可以知道data实际上为当前的页面绑定了一个Uri地址,通过Uri直接打开这个Activity

Uri的结构如下:

<scheme> :// <host> : <port> / [ <path> | <pathPrefix> | <pathPattern> ]

scheme和host不可缺省,否则配置无效;path,pathPrefix,pathPattern一般指定一个就可以了,pathPattern与host不可同时使用;mimeType可以不设置,如果设置了,跳转的时候必须加上mimeType,否则不能匹配到Activity。 

三、延迟深度链接

延迟深度链接,也称为Deferred Deep Linking,也就是深度链接的延迟版,实际上延迟深度链接是对深度链接功能的一个细分,是指在用户点击深度链接中打开APP的按钮时,如果手机没有安装APP能够自动跳转到APP的下载页面。

延迟深度链接对于APP而言最大的作用在于缩短了下载路径,能够有效地提升APP的下载量。我们回想一下没有延迟深度链接的场景,当用户收到一个好友发来的或者在Web上浏览的一个推广链接,比如是某电商APP的一件商品,如果他的手机没有安装该APP那么他的操作路径是“退出链接-打开应用商店-搜索APP-安装APP”,如果使用了延迟深度链接用户的操作路径就会优化成“点击链接内按钮-安装APP”。在这种优化之中,用户的主动操作只留下了最开始的按钮触发,既是对用户操作的一种体验优化,更减少了到达下载路径之前用户的主观思考环境,让用户在改变主意之前完成了下载。

实现方案:

在页面按钮上新增定时,默认调用启动App的URI,当超时时间达到的时候,如果未离开当前页就跳转到下载页面。

<script language="javascript"> 
function callApp( url ) {
    var timeout, t = 1000, hasApp = true;
    setTimeout(function () {
        if (hasApp) {
            alert('安装了app');
        } else {
            alert('未安装app');
        }
        document.body.removeChild(ifr);
    }, 2000)
    var t1 = Date.now();
    var ifr = document.createElement("iframe");
    ifr.setAttribute('src', url);
    ifr.setAttribute('style', 'display:none');
    document.body.appendChild(ifr);
    timeout = setTimeout(function () {
         var t2 = Date.now();
         if (!t1 || t2 - t1 < t + 100) {
             hasApp = false;
         }
    }, t);
}
</script>

注:此处存在一个问题,即在Android手机上会出现弹窗提示打开某App,此时如果没及时点击的话,可能后面会直接执行下载逻辑。

此问题,本人测试了openinstall和MobLink这两家的SDK,它们也没解决此问题。

下面是可以酌情参考的一些其他人的文章:

https://www.jianshu.com/p/69cc8c6a8f93

https://blog.csdn.net/qq_30740239/article/details/51969660 

四、技术拓展

1. 推荐阅读

https://blog.csdn.net/weixin_43652781/article/details/91800049

https://blog.csdn.net/weixin_40094522/article/details/87666254

https://blog.csdn.net/u011315960/article/details/82458806

2. 推荐相关SDK

openinstall:https://www.openinstall.io/pullUp.html

MobLink:https://www.mob.com/mobservice/moblink

posted @ 2020-06-27 10:19  灰色飘零  阅读(5407)  评论(0编辑  收藏  举报