article illustration Next.jsでCapacitorを使用してユニバーサルリンクを統合する方法
DeepLinking
Last update: December 14, 2023

Next.jsでCapacitorを使用してユニバーサルリンクを統合する方法

Next.js アプリケーションで Capacitor を使用して iOS および Android プラットフォーム向けにユニバーサルリンクを設定する方法を段階的に学びましょう。

iOSのユニバーサルリンクとAndroidのアプリリンクにより、ユーザーはリンクから直接アプリにアクセスでき、ブラウザをバイパスすることができます。これは、ユーザーエクスペリエンスの向上や、ウェブページからアプリへのコンテキストの維持に特に役立ちます。このガイドでは、Capacitorを使用してNextjsアプリのディープリンクを設定するプロセスについて説明します。

ディープリンクの設定には多くのコードは必要ありませんが、いくつかの構成が関与します。このガイドの終わりには、https://www.capgoapp/details/22のようなリンクをクリックし、アプリがインストールされている場合は正しいページが開く状態にすることができます。

Nextjsディープリンク設定

まず、新しいNextjsアプリとテスト用の詳細ページを作成します。

Terminal window
npx create-next-app@latest capgoLinks
cd capgoLinks
mkdir pages/details
touch pages/details/[id].js
npm run build
npx cap add ios
npx cap add android

capacitorconfigjsonファイルにバンドルIDが正しく設定されていることを確認してください。これは設定にとって重要です。

{
"appId": "com.capgo.deeplinks",
"appName": "capgoLinks",
"webDir": "out",
"bundledWebRuntime": false
}

ルーティングに関して、Nextjsはファイルベースのルーティングを使用しているため、pages/details/[id].jsというファイルを作成することで、既にワイルドカードルートが設定されています。

pages/details/[id].jsでは、Nextjsの組み込みルーターを使用してURLからIDを取得できます。

import { useRouter } from 'next/router'
function DetailsPage() {
const router = useRouter()
const { id } = router.query
return (
<div>
<p>My ID: {id}</p>
</div>
)
}
export default DetailsPage

次に、Capacitorを使ってappUrlOpenイベントを処理します。このイベントは、カスタムURLスキームを介してアプリが開かれたときにトリガーされます。pages/_app.jsファイルにリスナーを追加します。

import { useEffect } from 'react'
import { App } from '@capacitor/app'
function MyApp({ Component, pageProps }) {
useEffect(() => {
App.addListener('appUrlOpen', (event) => {
const slug = event.url.split('.app').pop()
if (slug)
window.location.href = slug
})
}, [])
return <Component {...pageProps} />
}
export default MyApp

このコードはappUrlOpenイベントをリッスンし、Nextjsアプリ内の適切なルートにナビゲートします。

iOS設定

iOSの場合、関連ドメインが有効なアプリIDが必要です。次の内容でapple-app-site-associationファイルを作成し、YOURTEAMIDcom.your.bundle.idを実際のチームIDとバンドルIDに置き換えます。

{
"applinks": {
"apps": [],
"details": [
{
"appID": "YOURTEAMID.com.your.bundleid",
"paths": ["*"]
}
]
}
}

このファイルをドメインのwell-knownディレクトリにアップロードし、https://www.capgoapp/well-known/apple-app-site-associationでアクセスできるようにします。

Xcodeで、applinks:capgoappの形式を使用してアプリの権限にドメインを追加します。

Android設定

Androidアプリリンクについては、以下の手順に従ってください。

  1. もしキーストアファイルを持っていない場合は生成してください。
  2. キーストアからSHA256フィンガープリントを取得します。
  3. パッケージ名とSHA256フィンガープリントを持つassetlinks.jsonファイルを作成します。
  4. このファイルをドメインのwell-knownディレクトリにアップロードします。

AndroidManifest.xmlで、ディープリンクを処理するactivity要素にintent-filterを追加します。

<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="capgo.app" />
</intent-filter>
</activity>

assetlinks.jsonファイルをアップロードした後、GoogleのDigital Asset Linksツールを使用して確認できます。すべてが正しく設定されていれば、緑のチェックマークが表示されます。

アプリをビルドし、署名するには、以下のコマンドを使用します。

Terminal window
cd android
./gradlew assembleRelease
cd ..
jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.keystore android/app/build/outputs/apk/release/app-release-unsigned.apk alias_name
zipalign -v 4 android/app/build/outputs/apk/release/app-release-unsigned.apk capgo.apk
adb install capgo.apk

これにより、接続されたAndroidデバイスに署名されたアプリがインストールされます。

Capacitorのネイティブプロジェクト設定の構成

ネイティブプロジェクト設定を自動化するために、Capacitor configureパッケージの使用を検討してください。プロジェクトにインストールします。

Terminal window
npm install @capacitor/configure

プロジェクトのルートにcapacitorconfig.yamlファイルを作成します。

vars:
BUNDLE_ID: com.capgo.deeplinks
PACKAGE_NAME: com.capgo.deeplinks
platforms:
ios:
targets:
App:
bundleId: $BUNDLE_ID
entitlements:
- com.apple.developer.associated-domains: ['applinks:capgo.app']
android:
packageName: $PACKAGE_NAME

この構成で構成ツールを実行します。

Terminal window
npx cap-config run capacitor.config.yaml

これにより、YAMLファイルに指定された設定がネイティブプロジェクトに適用されます。

結論

Nextjsアプリ用にCapacitorでディープリンクを設定するには、iOSおよびAndroidの両方についてドメインとプロジェクト設定の構成が必要です。このプロセスは細部に注意を必要としますが、古い方法と比べて効率的であり、追加のプラグインは必要ありません。ドメイン検証ファイルが正しく提供されていることを確認し、それらを各プラットフォームのツールでチェックしてください。設定が完了すると、ユーザーはウェブからアプリに移行する際にスムーズでシームレスな体験が得られます。

最新のニュース

Capgoは、真にプロフェッショナルなモバイルアプリを作成するために必要な最高のインサイトを提供します。