使用通用链接和应用链接实现深度链接
平台: 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 Router 的第一方路由系统,与 Vue 原生集成。要设置 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。