49

在我阅读的过程中,iOS 9 引入了 Universal Links。在 Apple's App Search Programming Guide的“支持通用链接”部分中,它说这与使用 URL 方案的深度链接不完全一样,但我对这个主题并不完全清楚:

  • 通用链接和 URL 方案之间实际上有什么区别?通用链接是否仅适用于网站中的超链接以及邮件或消息应用程序?
  • 通用链接会取代 URL 方案吗?
  • 通用链接是一种深层链接吗?
4

4 回答 4

81

长话短说:

通用链接和 URL 方案之间实际上有什么区别?通用链接是否仅适用于网站中的超链接以及邮件或消息应用程序?

通用链接是 Apple 特定的、基于操作系统的 URL,它将网站 URL 与特定于应用程序的 URI 方案和路由联系起来。它并非在所有应用程序中都可用 - 因为应用程序必须支持该行为。有一个很好的清单,列出了 UL 当前的工作地点/方式(此处)。

UL 也有很多问题,我在最后概述了这些问题。请参阅下面的长读。

通用链接会取代 URL 方案吗?

不,它们是 iOS Safari 上 URI 方案和路由的强制替代品。你必须而且应该仍然支持你的应用程序的 URI 方案和路由,因为 Android 和 iOS Chrome 仍然使用这项技术,从归因到电子邮件的所有主要类型的链接供应商也是如此。

通用链接是一种深层链接吗?

是和不是。通用链接本身不是通用深层链接 - 例如,它们无法通过安装过程。但是当用户拥有应用程序时,他们可以进行深度链接。最好考虑所有链接可以做什么和不能做什么,而不是将 URL 分为“深度链接”和“非深度链接”。

许多链接根据用户是否拥有应用程序和上下文(浏览器、应用程序、操作系统、操作系统版本等)而表现出深度链接的行为。改变思维框架。

跟踪通用链接

在下面的文档中,我概述了通用链接的所有不同方面。重要的是要指出continueUserActivity将报告来自通用链接的引用 URL,因此您可以使用它来属性打开。

因为 UL 不是正常链接,所以如果您有重定向,就会破坏它。同样,如果您关闭重定向,那么您拥有的任何网站点击服务器都将永远不会受到攻击。这是一个不同的讨论,但重要的是要注意。

如果您有兴趣,我在下面的 Universal Links 上整理了很多有用的信息。

URI 方案

大多数人都熟悉 URI 方案。URI 是一个通用资源指示符(链接)。URI 可以分配给移动应用程序。键入 URI,如 airbnb:// 将尝试在设备上定位应用程序资源 Airbnb。

在 Universal Links 或 App Links 存在之前(即在 iOS 9.3/Android 6.0 之前),需要使用“自定义 URI 方案”和以下形式的路由将airbnb://d/listing/530250用户深度链接到移动应用程序中的特定内容(在这种情况下是一个列表)。然而,当用户没有安装应用程序(没有回退)时,这并不安全,也不能处理这种情况。大多数归因合作伙伴(Appsflyer、Kochava、Button、Yozio、Branch 等)的工作方式是他们会提供一个链接来处理这个问题。

当用户访问这个 URL 的页面时,会有一些 javascript 设置一个计时器,然后尝试使用一些简单的 javascript 从浏览器启动 URI 方案:

window.location.href(...)

如果应用程序在计时器到期之前没有打开,那么供应商可以假设手机不包含应用程序,因此,一些 javascript 会触发以打开 iTunes 或 Android URL。这种机制依赖于在浏览器中阻止 javascript。

在 iOS 9.3 中,Apple 移除了 Safari 中的阻塞 JavaScript(链接)。最终结果是,每当您尝试在 Safari 中打开具有 URI 方案的应用程序时,您都会看到一条大错误消息,上面写着“无法打开页面”。这是一种糟糕的用户体验,并导致苹果新系统 Apple Universal Links 的实施。

苹果浏览器

Apple Universal Links & Android App Links 本质上是 Web URL(例如,https://www.airbnb.com/rooms/530250),旨在将用户引导到 Web 或应用程序上的最佳位置。如果用户没有应用程序,它们旨在将用户带到移动网络,但如果用户有应用程序,则将用户带到应用程序中的确切内容。在移动设备上,如果用户点击通用链接并安装了我们的应用程序,他们可能会被定向到该应用程序,否则系统将回退并让访问者登陆我们的移动网站(有一些例外 - 见下文)。

对于真正通用的链接,它要求在 Web、iOS 和 Android 上启用链接功能,并且所有应用程序共享相同的资源路径。

苹果通用链接和安卓应用链接

Apple Universal Links (iOS) 和 Android App Links (Android) 本质上是相同的概念,但经常互换,或与其他路由机制混淆。当您谈论这些概念时,明确说明这一点很重要,否则您可能会混淆或混淆运行方式非常不同的不同技术。

具体来说,Apple Universal Links 是 Apple 的一项标准,部署在 iPhone 操作系统 (OS) 上,允许用户点击链接并在拥有该链接时立即传送到应用程序。Apple 通用链接没有重定向。这是一个特殊的系统设置,具有一定程度的技术复杂性。当用户点击链接时,会向 Apple 发起往返服务器调用,操作系统会立即打开应用程序,而无需打开浏览器或加载 URL。更多关于它是如何工作的如下。

Android App Links 是在 Android 上设置的等效链接系统。

通用链接首先为您的每个域托管一个“Apple 应用程序站点关联文件”(AASA)。

需要注意的是,几乎每家公司的 AASA 都托管在其主域中,然后是“/apple-app-site-association”</p>

一些例子:

https://www.jet.com/apple-app-site-association https://www.pinterest.com/apple-app-site-association

如果单击这些 URL,它将下载公司的 AASA。AASA 示例在右侧。AASA 中包含的一些值得注意的东西: 可以应用通用链接的所有应用程序的 AppID。在我们和许多其他 AASA 中,您将看到应用程序的生产和测试版本的设置,以便链接将在所有版本中工作以进行测试。AppID 的结构为 App Prefix,后跟 Bundle ID。通常应用程序的每个测试版本都有不同的前缀,但 Bundle ID 保持一致。

示例... {App Prefix}.{ Bundle ID }

路径:如果用户拥有它,这些路径将立即打开应用程序。该应用程序将收到引用 URL,并可以解析出正确的路径,以将用户深层链接到之后的内容。

大多数归因供应商,如 Branch 或 Appsflyer,也可以在某些情况下为您托管 AASA(例如:Branch 的 Airbnb AASA 托管在自定义域https://abnb.me/apple-app-site-association上)。

这些文件有效地将要在应用程序中映射或不映射到的 URL 列入白名单和黑名单。就像公司拥有的 AASA 一样,对于每个域,供应商都会指定 App ID 和 URL 路径,例如:

5LL7P8E8RA.com.airbnb.app
"/rooms/*"
"/wishlists/*"
"/invite"
"NOT /rooms/*/building-rules"

当用户安装或升级我们的应用程序时,iOS 会获取我们应用程序权利中列出的所有域的 AASA 文件,以确保我们的网站允许我们的应用程序代表他们打开 URL。

通用链接的已知问题

通用链接在大多数情况下工作得很好,但是这些很容易并且在不经意间被禁用!如果发生这种情况,用户将始终被重定向到网站 URL,直到他们升级他们的应用程序或重置我们所谓的“权利文件”(链接)。

如果用户点击我们应用右上角的“airbnb.com”或“abnb.me”链接,操作系统会将用户引导至该网站,但它也会将任何未来的通用链接永久引导至移动设备与该域的链接的网站!

这有效地破坏了用户的 Apple 通用链接的功能。这目前无法跟踪,唯一的重置方法是长按 URL 并单击“在“Airbnb”中打开”(不直观)或点击 Apple 通用链接横幅(幻影横幅)上的“打开”按钮本文档前面已描述。

苹果通用链接横幅

这些 AASA 路径还用于确定何时显示或不显示 iOS 系统的“通用链接横幅”。

这是一个特别热门的话题,经常在谈话中出现,值得讨论。

当您在特定域上启用 Apple 通用链接时,Apple 将在 Safari 浏览器上注入系统应用程序横幅。这意味着除了我们显示的任何横幅或网络插页式广告之外,Apple 还将强制使用不可自定义、不可跟踪的通用链接横幅,该横幅显示在 Safari 顶部,供拥有该应用并在 Safari 中查看 URL 的用户使用谁的路径在 AASA 中。

苹果注入了一个

我们无法控制此横幅的外观。我们只能根据 AASA 确定它是否应该在页面上可见。我们目前也无法确定用户是否或何时点击“打开”按钮(IE 无归属。

Apple Universal Links Banner 属性总结:

于 2017-08-06T15:19:41.703 回答
57

通用链接是 iOS 向给定应用程序发送 Web url 请求的能力,而不是在浏览器中打开它们。

URL-schemes 是一种应用程序在给定状态下打开的能力,由 url 描述,并由开发人员在代码中处理。

假设您有一个名为“Cool App”的应用程序,并且您已经注册了 url-scheme “coolapp”。而且您的应用程序具有不同的区域,例如“Nice gadgets”和“Nice stuff”。现在您可以使用 at link 链接打开您的应用程序coolapp://nice-gadgets。要在 nice gadget 部分打开应用程序,您必须实现该application(_:openURL:options:)方法,并在其中发现请求的 url,并使应用程序打开请求的视图控制器。

同时你有一个网站叫www.coolapp.com. 使用 iOS 设备浏览时,您会遇到指向您网站的链接 - 例如www.coolapp.com/nice-gadgets,打开该链接,它将在浏览器中打开。通过启用通用链接,它将通过调用application(_:continueUserActivity:restorationHandler:)给定 url 作为参数的方法来打开应用程序。从这里您可以使用与 url 方案处理相同的逻辑,以请求状态打开应用程序。

那么通用链接会取代 url 方案吗?我对此表示怀疑,但他们会以一种很好的方式互相恭维。

通用链接是深层链接吗?不可以,但他们可以启动在应用程序中使用深层链接的过程。

于 2016-02-20T12:04:03.000 回答
14

通用链接替换 ​​URL/URI 方案?

在 Apple 的理想世界中,的!


通用链接是一种深层链接?

因为 Apple 强制向开发者用户 Universal Links 以进行深度链接。因此,Universal Links 是 Apple 的一种深度链接。但是如果你看到 Facebook 持续的 SDK,他们实现了自己的 WebView 以支持 iOS 9.0 + 中的深度链接。因此,对于 Apple 通用链接来说,比深度链接更好。

于 2016-03-07T19:19:38.820 回答
9

这是一个通用链接示例:“<a href="http://sample-universal-link.demoapp.com" rel="noreferrer">http://sample-universal-link.demoapp.com”</p >

它是独一无二的,在被点击时,它会 在不通过 Safari 的情况下打开应用程序(如果已安装应用程序)将在 Safari 上打开网站(如果未安装应用程序)

这是一个示例 URL 方案:“demoapp” (demoapp://params)

可能不是唯一的,如果已安装,点击它会打开应用程序。如果该应用程序没有安装它不会做任何事情。一个或多个 App 可能有相同的 URL Scheme。

通用链接和 URL 方案的实现(要求)有很大不同,所以我非常怀疑通用链接是否会取代 URL 方案。

通用链接是实现深度链接的方式之一。

于 2017-03-17T07:16:05.293 回答