使用通用链接和应用链接进行深度链接
平台:iOS、Android
通用链接(iOS)和应用链接(Android)提供了将用户直接带到本机应用中特定内容的能力(通常称为深度链接)。
当用户点击或点击深度链接时,用户将直接发送到您的应用中,而无需通过设备的网络浏览器或网站进行路由。如果未安装应用,则用户将被定向到网站。如果用户直接导航到网站,他们将留在网站上。这使得深度链接成为为 Web、iOS 和 Android 构建的跨平台应用的绝佳功能:无缝的移动体验,优雅地回退到网站。
好处:
- 安全:通用/应用链接使用链接到您拥有的网站域的 HTTPS URL,确保没有其他应用可以使用您的链接。
- 无缝体验:一个 URL 适用于您的网站和应用,确保用户可以成功访问他们正在寻找的内容而不会出错。
- 增加参与度:可以从电子邮件客户端、搜索引擎结果等打开链接。
演示视频
这是实际效果。在此示例中,用户已安装了本机应用。他们从电子邮件中点击应用链接,并直接进入应用本身。首 先,点击根链接(https://beerswift.app),将用户定向到主应用页面。接下来,点击深度链接(https://beerswift.app/tabs/tab3),将用户带到 Tab3 页面。
先决条件
- 一个预配置的 Capacitor 应用。
- 对于 iOS,需要注册 Apple Developer Program。
出于说明目的,https://beerswift.app 将用作 Web 应用链接。
使用 Capacitor App API 进行深度链接路由
当在点击深度链接后打开本机应用时,移动操作系统不会自动知道将用户路由到哪里。这必须在应用内部使用 Capacitor App API 在应用启动时实现。
如果您的网站和应用路径不匹配,您将需要实现更高级的 url 模式匹配(请参阅此指南以获取示例)。但是,如果您的移动应用和 Web 应用使用相同的代码库,这非常简单 - 只需重定向到相同的 URL。以下示例假设了这一点。
Angular
路由应该在 app.component.ts 中实现。首先从 Angular 导入 NgZone 和 Router,然后从 Capacitor 导入 App:
import { Component, NgZone } from '@angular/core';
import { Router } from '@angular/router';
import { App, URLOpenListenerEvent } from '@capacitor/app';
接下来,将 Router 和 NgZone 添加到构造函数:
constructor(private router: Router, private zone: NgZone) {
this.initializeApp();
}
最后,监听 appUrlOpen 事件,并在发现深度链接时重定向:
initializeApp() {
App.addListener('appUrlOpen', (event: URLOpenListenerEvent) => {
this.zone.run(() => {
// 示例 url:https://beerswift.app/tabs/tab2
// slug = /tabs/tab2
const slug = event.url.split(".app").pop();
if (slug) {
this.router.navigateByUrl(slug);
}
// 如果没有匹配,则不执行任何操作 - 让常规路由
// 逻辑接管
});
});
}
React
React 有多种选择。一种方法是将 App API 监听器功能包装在一个新组件中,然后将其添加到 App.tsx 内部。首先创建 AppUrlListener.tsx,然后导入 React Router useHistory 钩子以及 Capacitor App API:
import React, { useEffect } from 'react';
import { useHistory } from 'react-router-dom';
import { App, URLOpenListenerEvent } from '@capacitor/app';
接下来,定义 AppUrlListener 组件,监听 appUrlOpen 事件,然后在发现深度链接时重定向:
const AppUrlListener: React.FC<any> = () => {
let history = useHistory();
useEffect(() => {
App.addListener('appUrlOpen', (event: URLOpenListenerEvent) => {
// 示例 url:https://beerswift.app/tabs/tab2
// slug = /tabs/tab2
const slug = event.url.split('.app').pop();
if (slug) {
history.push(slug);
}
// 如果没有匹配,则不执行任何操作 - 让常规路由
// 逻辑接管
});
}, []);
return null;
};
export default AppUrlListener;
在 App.tsx 中,导入新组件:
import AppUrlListener from './pages/AppUrlListener';
然后将其添加到 IonReactRouter 内部(或应用启动的任何位置,只需确保 History 钩子可用):
const App: React.FC = () => {
return (
<IonApp>
<IonReactRouter>
<AppUrlListener></AppUrlListener>
<IonRouterOutlet>
<Route path="/home" component={Home} exact={true} />
<Route exact path="/" render={() => <Redirect to="/home" />} />
</IonRouterOutlet>
</IonReactRouter>
</IonApp>
);
};
Vue
VueJS 提供了一个与 Vue 原生集成的第一方路由系统,称为 Vue Router。要使用 Vue Router 设置深度链接,请从用于配置所有路由的文件(通常是 routes.js 或类似的文件)开始。
首先,我们从插件中导入 capacitor App 以及 Vue 和 VueRouter。
import { App, URLOpenListenerEvent } from '@capacitor/app';
import Vue from 'vue';
import VueRouter from 'vue-router';
接下来,使用 Vue Router 配置您的路由(有关 Vue Router 入门的更多信息)。
const router = new VueRouter({
routes: [],
});
建议使用 mode: history,这样您就不必处理 #。
让 Vue 知道您正在使用 Vue Router,并在 Vue 中注册路由器:
const VueApp = new Vue({
router,
}).$mount('#app');
最后,我们需要为深度链接注册我们的应用。为此,我们在 Capacitor App 的 appUrlOpen 事件上添加一个事件监听器。Capacitor 将接收此事件,然后将其移交给 Vue Router 以导航到请求的页面。
App.addListener('appUrlOpen', function (event: URLOpenListenerEvent) {
// 示例 url:https://beerswift.app/tabs/tabs2
// slug = /tabs/tabs2
const slug = event.url.split('.app').pop();
// 只有当存在 slug 时,我们才推送到路由
if (slug) {
router.push({
path: slug,
});
}
});
创建站点关联文件
为了允许 Apple 和 Google 允许深度链接打开您的应用,必须在您的网站和应用之间创建双向关联。必须为每个创建一个文件,并将其放置在您网站的 .well-known 文件夹中,如下所示:https://beerswift.app/.well-known/。
继续阅读 iOS 和 Android 配置详细信息。
iOS 配置
iOS 配置涉及创建站点关联文件和配置本机应用以识别应用域。
您必须注册 Apple Developer Program。
创建站点关联文件
首先,登录到 Apple Developer 站点。导航到"Certificates, Identifiers & Profiles"部分,并选择您应用的标识符。记下 Team ID 和 Bundle ID,然后在 Capabilities 下,切换"Associated Domains"并保存:

接下来,创建站点关联文件(apple-app-site-association)。
注意:尽管这是一个 JSON 文件,但不要保存它时使用文件扩展名。
下面是 apple-app-site-association 文件的示例。确保将 TEAMID.BUNDLEID 替换为您自己的 ID(例如:8L65AZE66A.com.netkosoft.beerswift)。
{
"applinks": {
"apps": [],
"details": [
{
"appID": "TEAMID.BUNDLEID",
"paths": ["*"]
}
]
}
}
接下来,将文件上传到您的网站(通过 HTTPS 托管),然后使用 Apple 的工具在此处验证其配置是否正确。URL 应遵循此格式:https://beerswift.app/.well-known/apple-app-site-association
添加关联域
最后一步是配置 iOS 应用以识别传入的链接。打开 Xcode,然后导航到 Signing & Capabilities。单击"+ Capability",然后选择 Associated Domains。在出现的 Domains 条目中,使用格式 applinks:yourdomain.com 进行编辑:

Android 配置
Android 配置涉及创建站点关联文件和配置本机应用以使用 intent 过滤器识别应用链接。
创建站点关联文件
站点关联文件需要您的 Android 证书的 SHA256 指纹。
如果您没有,请创建证书:
keytool -genkey -v -keystore KEY-NAME.keystore -alias ALIAS -keyalg RSA -keysize 2048 -validity 10000
使用您现有的(或新创建的)Keystore 证书,使用 keytool 命令列出 keystore 的详细信息:
keytool -list -v -keystore my-release-key.keystore
打印的输出将包括 SHA256 指纹:

接下来,使用 Google 的 Asset Links 工具创建站点关联文件。填写网站域、应用包名称和 SHA256 指纹,然后单击"Generate statement":

将 JSON 输出复制到 .well-known/assetlinks.json 下的新本地文件中。
// assetlinks.json
[
{
"relation": ["delegate_permission/common.handle_all_urls"],
"target": {
"namespace": "android_app",
"package_name": "com.netkosoft.beerswift",
"sha256_cert_fingerprints": ["43:12:D4:27:D7:C4:14..."]
}
}
]
将文件部署到您的网站(通过 HTTPS 托管),然后通过在 Asset Link 工具中单击"Test statement"按钮来验证它。如果配置正确,将出现成功消息:
Success! Host [website] grants app deep linking to [app package].
添加 Intent 过滤器
最后一步是配置 Android 应用以识别传入的链接。为此,添加新的 Intent 过滤器到 AndroidManifest.xml 中的 <activity> 元素:
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" android:host="beerswift.app" />
</intent-filter>
完整的 Activity 应类似于:
<activity
android:configChanges="orientation|keyboardHidden|keyboard|screenSize|locale"
android:name="com.netkosoft.beerswift.MainActivity"
android:label="@string/title_activity_main"
android:theme="@style/AppTheme.NoActionBarLaunch"
android:launchMode="singleTask">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="https" android:host="beerswift.app" />
</intent-filter>
</activity>
网站配置
网站配置将根据所使用的工具和后端而有所不同。以下是一些建议。
Angular
将关联文件放在 src/.well-known 下。接下来,配置构建过程以完全按原样部署这些文件(确保 Apple/Google 可以正确读取它们)。打开 angular.json 并在 architect => assets 下,向数组添加新条目:
{
"glob": "**/*",
"input": "src/.well-known",
"output": ".well-known/"
}
然后构建并部署站点。
NuxtJS
将关联文件放在 static/.well-known 下。不需要其他步骤;只需构建然后部署站点。
React
将关联文件放在 public/.well-known 下。不需要其他步骤;只需构建然后部署站点。
WordPress
请参阅此处以获取 WordPress 说明。
验证
要验证网站和本机应用配置是否正确,网站需要托管站点关联文件,但应用不需要在应用商店中。
将设备连接到计算机,构建并部署本机应用,然后通过点击网站链接进行测试。如果本机应用打开,则所有步骤都已正确实施。
资源
- Branch.io:什么是深度链接?
- Android:应用链接
- iOS:通用链接
- iOS:在应用中支持通用链接