点击链接启动APP 深度连接及Android App Links

 

以下基本上是基于studio 自带的工具完成,自认为工具本身就是方便我们使用的,不用岂不是白费了,当然自己也要记得什么是什么。

  首先,来看看android中的两类链接: 
  1、深链接Deep linking 
    深链接即我们通常说的scheme跳转,需要我们在清单文件中对activity添加intent-fillter,并定义scheme(包括但不限于HTTP协议)。如果用户手机内安装了多款能响应链接启动的应用,那么系统会弹出一个选择器,让用户自主选择用哪个应用打开(可能不是你的应用)。 
  2、安卓软件链接组 Android App Links 
    Android App Links是6.0以后才支持的链接方式,APP通过定义一组你自有的HTTP URL将该其设置为系统的默认打开对应域名的地址的应用(注意区分:不是6.0以下的默认打开某类数据)。当用户点击了包含你的域名的链接时,系统默认用你的APP打开该链接,如果用户手机未安装你的APP,那么会直接用浏览器打开。手机里的其他应用则不能打开。 

   自认为的缺陷(不对的请纠正,Thanks♪(・ω・)ノ):

  • app links只能工作在Android 6.0以上,但是不排除某些产商在自改的5.x系统中就加入了这一功能。
  • 得维护一个专门的M站。
  • 目前测试只在Chrome上可以完美运行,其他浏览器(UC、QQ浏览器等)都不支持。

  3、Deep linking和App Links区别一览图

区别项Deep lingkingApp Links
Intent URL schemehttp,https,自定义协议http,https
Intent action任何action需要android.intent.action.VIEW
Intent category任何category需要android.intent.category.BROWSABLE和android.intent.category.DEFAULT
链接验证不验证通过DAL文件和https验证
用户体验可能会弹出一个APP选择弹框让用户选择用哪个应用打开不弹APP选择弹框,直接用你的APP打开(已安装,否则直接打开网页)
兼容性所有版本系统6.0及以上

  因此,Android App Links相对于Deep linking有以下几点优势: 
  1、安全:因为只有你自己的APP能打开,所以很可靠; 
  2、无缝的用户体验:因为只有自己的APP可以打开,所以不会出现让用户选择哪个应用的打开的弹框,如果用户没有安装你的APP,则直接用浏览器打开。 
  3、支持免安装的谷歌应用:当然,这条优势对国内开发者来说没什么影响,因为谷歌的免安装应用需要上传到google player。 
  4、支持从浏览器、谷歌搜索APP、手机快捷搜索和谷歌助手等多个地方通过链接启动APP。 
   
  Deep linking支持: 
  当用户点击一个链接时,系统默认按以下顺序打开: 
  1、如果你设置了默认打开应用,则优先使用该应用打开; 
  2、如果只有一个应用能打开,则直接用该应用打开; 
  3、如果有多个应用能打开,才会弹出应用选择弹框。 
   
  以下就是一个支持Deep linking启动的activity的意图配置模板,注意看注释:

<activity android:name=".SecondActivity">
            <intent-filter>
                <!--必须的action-->
                <action android:name="android.intent.action.VIEW"/>
                <!--必须的category-->
                <category android:name="android.intent.category.DEFAULT"/>
                <!--必须的category-->
                <category android:name="android.intent.category.BROWSABLE"/>
                <!--支持以"http://www.jack_bear_csdn.com"开始的uri打开-->
                <data android:host="www.jack_bear_csdn.com" android:scheme="http"/>
            </intent-filter>

            <intent-filter>
                <!--必须的action-->
                <action android:name="android.intent.action.VIEW"/>
                <!--必须的category-->
                <category android:name="android.intent.category.DEFAULT"/>
                <!--必须的category-->
                <category android:name="android.intent.category.BROWSABLE"/>
                <!--支持以"jackxiong://www.jack_bear_csdn.com"开始的uri打开-->
                <data android:host="www.jack_bear_csdn.com" android:scheme="jackxiong"/>
            </intent-filter>

        </activity>

  通过ADB命令检测是否配置正确 
  如果通过以下命令能够打开目标activity,则说明我们的配置无误: 
   adb shell am start 
  -W -a android.intent.action.VIEW 
   -d < 你配置的Uri> < 你的APP包名>

  根据我上面的配置代码,那么我的adb命令对应如下图: 
  这里写图片描述
  从上图中可以看出,通过以 http://和jackxiong://开头的协议启动目标activity的命令均Complete了,说明配置是正确的。 
   
  Android App Links支持 
  Android App Links也免不了需要在清单文件里为activity声明意图过滤器,只不过它声明的是一个可用的url,如果你的android studio是2.3以上的版本,而且你也不想自己写intent-filter部分的代码,我们可以通过android studio的APP链接助手来实现半自动的为目标activity添加intent-filter: 
  1、点击Tools选择App Links Assistant打开助手面板 
  这里写图片描述
  2、点击助手面板中的Open URL Mapping Editor按钮打开activity和url映射配置的操作面板 
  这里写图片描述
  从上图中我们可以看到,当我们打开这个操作面板时: 
  区域1:会默认显示我们APP中所有声明了url意图过滤器的activity及其对应的url详情; 
  区域4:当我们在区域1中选中了某天映射时,该activity及其intent-filter在清单文件中的代码可以在区域4中得到预览; 
  区域2:我们可以对已选中的某条映射关系进行删除、修改,也可以为某个activity新增intent-fillter; 
  区域3:我们可以在这里输入一个url,操作面板会告知我们这个url是用在哪个activity上; 
  3、为activity新增intenr-filter 
  点击区域2中的 + 打开新增面板 
  这里写图片描述
  在这个面板中选中目标activity,配置host、path(可选)后点击Ok即可。 
  例如我有一个未配置意图过滤器的ThirdActivity,在清单文件中是这样的: 
  这里写图片描述 
  我们在新增面板中为该activity新增配置后,再看看清单文件是怎样的。 
  这里写图片描述 
  下图就是配置后的ThirdActivity意图 
  这里写图片描述 
  我们可以看到,和我们手写的intent-filter一毛一样! 
  4、为目标activity自动插入解析对应intent的代码 
  例如我的ThirdActivity空空如下: 
  这里写图片描述 
  现在,我们点击app链接助手面板中的Select Activity按钮,选中ThirdActivity点击Insert Code后怎么样: 
  这里写图片描述
  以下就是插入代码后的ThirdActivity 
  这里写图片描述 
   
  5、生成链接数字证书文件Digital Asset Links(DAL) 
  点击打开链接助手的Open Digital Asset Links File Generator按钮,打开关联网站操作面板: 
  这里写图片描述
  这里写图片描述
  我们可以看到: 
  区域1:域名和包名已经自动填充好了 
  区域2:这里可以设置是否让网页和我们的APP共享用户的登陆信息,如果选择支持的话,需要键入网页的登陆地址,并且在我们的DAL证书中的relation项的值就变为:delegate_permission/common.get_login_creds。 
  我这里只是测试,就不支持共享登陆信息了。 
  区域3:这里可以选择我们的DAL证书是在debug环境用还是release环境用,如果选择生成的是release环境的证书,就还需要选择我们release打包用的keystore文件。 
  区域4:当我们点击Generate Digital Asset Links 按钮后,这里就可以预览我们生成的DAL文件详情了。我们可以看到,由于我在区域2中未勾选允许网页和App共享登陆信息,所以生成的DAL文件的relation的值为:delegate_permission/common.handle_all_urls。 
  然后点击Save file按钮,将我们的DAL文件下载下来,让后台人员把它上传到域名下的 .well-known目录下即可(注意:该目录以一个点开头,且Content-Type必须是application/json添加到http响应头)。例如我这里的域名是http://www.jack_bear_csdn.com,那DAL文件在服务器中的路径就是:http://www.jack_bear_csdn.com/.well-known/assetlinks.json。 
  区域5:完成了以上步骤,我们点击Link and Verify按钮,会产生以下结果: 
  5.1:项目res目录下的strings文件会生成一个名字为asset_statements的字符串: 
  这里写图片描述
  5.2:产生的字符串会被添加到清单文件中的application节点下: 
  这里写图片描述
  5.3:对应的activity的intent-filter里会加入一个是否自动认证的属性: 
  这里写图片描述 
  6、测试你的链接 
  完成了以上配置工作,我们回到链接助手面板,点击Test App Links按钮进入测试面板,键入对应的Url后点击Run Test按钮,可以模拟用户点击链接的操作: 
  这里写图片描述

  到这里,我们可以知道:Android App Links之所以能够确保只有自己的App能打开对应的链接是因为DAL文件的作用。我们可以在6.0以上的手机中看到App都能被哪些链接打开,如下图: 
  这里写图片描述 
  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值