码迷,mamicode.com
首页 > 其他好文 > 详细

如何简单快速地实现深度链接?

时间:2020-07-06 11:01:04      阅读:85      评论:0      收藏:0      [点我收藏+]

标签:通过   名称   ios   网页   字符串   项目   提高   enter   标签   

什么是深度链接?

深度链接是一种将用户引导下载应用的有效方法,可以提供良好的用户体验,从而提高应用的拉新、转化和留存率。用户在浏览器中打开点击深度链接时,可以实现网页到应用之间的无缝切换,并可以通过携带参数,实现直达应用的指定场景页面的功能。

 

如何实现从网页启动APP?

不同于常见的URL中http://开头的协议,深度链接的开头可以自行定义。这里以mytest://为例:

首先在项目的Androidmanifest.xml文件里面添加一个<intent-filter>标签,

1 <intent-filter>
2     <action android:name="android.intent.action.VIEW" />
3     <category android:name="android.intent.category.DEFAULT" />
4     <category android:name="android.intent.category.BROWSABLE" />
5     <!--配置自定义的scheme,至少需要scheme和host才能匹配-->
6     <data android:scheme="mytest"
7           android:host="xxx.xx.xxx.xxx"/>
8 </intent-filter>

 

然后在拉起页面中添加点击跳转的链接,格式为scheme://host:port/path?paramKey=paramValue,这里以mytest://开头为例:

<a id="downloadButton" href="mytest://xxx.xx.xxx.xxx:80/mypath?key=value" >OpenApp</a>

技术图片

<intent-filter>标签的添加位置,决定拉起时进入到对应的Activity。

 

拉起的Activity中添加获取获取参数的方法:

1 Log.d(TAG, "scheme:"  + intent.getScheme());
2 //Log.e(TAG, "host:"  + intent.getData().getHost());
3 Uri uri = intent.getData();
4 Log.d(TAG, uri.getScheme()); // 获取 scheme 名称
5 Log.d(TAG, "host: " + uri.getHost());     // 获取 scheme 的host
6 Log.d(TAG, "path: " + uri.getPath());     // 获取 scheme 的路径
7 Log.d(TAG, "port: "+uri.getPort());         //获取端口号
8 Log.d(TAG, "queryString: "+  uri.getQuery()); // 获取 scheme 的参数?后面的部分
9 Log.d(TAG, "queryParameter: " + uri.getQueryParameter("key")); // 获取 paramKey 的 paramValue 参数

 

如此便可在应用中获取到从网页传来的参数:

技术图片

 

进阶使用

随着移动端应用推广的竞争越来越激烈,对于深度链接的要求也越来越高。如何实现用户未安装应用时,下载安装后也可以直达特定的场景页?iOS如何直接在微信中拉起应用?如何做到应用与其下载网页中携带参数的精确匹配?......这里以openinstall提供的第三方SDK为例:

按照其文档指示,仅需导入jar包并复制相关代码到网页端和应用端中即可,其中openinstall提供了一个系统随机分配的字符串做为拉起用到的scheme,

技术图片

其中网页的参数跟上面的格式相同,以键值对的形式拼接到落地页链接后面即可,多个参数中间以&符号链接,这里以一个demo为例,可以简单实现从网页到拉起应用后,其携带的参数自动填写到应用中的场景:

技术图片

开发人员可以根据自己应用的需求,拿到拼接参数后做二次处理,如实现指定商品页面的直达的应用场景。简单快速的几步,便可以大幅度优化用户的使用体验,真正地将网页与应用相结合,让APP运营推广变得更加灵活。

如何简单快速地实现深度链接?

标签:通过   名称   ios   网页   字符串   项目   提高   enter   标签   

原文地址:https://www.cnblogs.com/Tu2k1/p/13253279.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!