はじめに
インストール手順とこのプラグインの完全なマークダウンガイドを含むセットアッププロンプトをコピーする
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-network-diagnostics`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/network-diagnostics/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
インストール
「インストール」というセクションAI-Assisted Setupを使用してプラグインをインストールできます。AIツールにCapgoスキルを追加するには、以下のコマンドを使用してください。
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins次に、以下のプロンプトを使用してください。
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-network-diagnostics` plugin in my project.手動設定を選択する場合は、以下のコマンドを実行してプラグインをインストールし、以下のプラットフォーム固有の指示に従ってください。
npm install @capgo/capacitor-network-diagnosticsnpx cap syncインポート
「インポート」のセクションimport { NetworkDiagnostics } from '@capgo/capacitor-network-diagnostics';完全な診断レポートを実行
「完全な診断レポート」を実行するセクションrunDiagnostics ユーザーが制限されたネットワーク上にある場合、サポートレポートを収集する最速の方法です。
const report = await NetworkDiagnostics.runDiagnostics({ urls: [{ url: 'https://api.example.com/health', method: 'HEAD' }], ports: [{ host: 'api.example.com', port: 443 }], websockets: [{ url: 'wss://ws.example.com/socket' }], download: { url: 'https://speed.example.com/5mb.bin', maxBytes: 5 * 1024 * 1024, }, packetLoss: { mode: 'tcp', host: 'api.example.com', port: 443, count: 10, },});
console.log(report.status.connectionType);console.log(report.issues);現在のネットワーク状態を確認
現在のネットワーク状態を確認するconst status = await NetworkDiagnostics.getNetworkStatus();
console.log(status.connected);console.log(status.connectionType);console.log(status.internetReachable);console.log(status.captivePortal);プラットフォームによっては、正しいフラグが異なります。Androidは、有効化されたインターネットとキャプティブ ポータル状態を報告します。iOSは、パス状態、インターフェイスタイプ、コストの高いパス、制約されたパスを通じて Network.framework.
API の到達可能性をテストする
セクションのタイトル:API の到達可能性をテストするconst result = await NetworkDiagnostics.testUrl({ url: 'https://api.example.com/health', method: 'HEAD', timeoutMs: 5000, followRedirects: true,});
if (!result.reachable) { console.warn(result.errorCode, result.errorMessage);}実際のヘルスエンドポイントからバックエンドを使用します。ブラウザのみのチェックは、WebView、CORS、プロキシ、またはキャプティブ ポータル動作によって隠される可能性があります。このプラグインは、ネイティブ ネットワーキングを使用するため、異なるものです。
__CAPGO_KEEP_0__ のTCPポートをテストする
セクションのタイトル:__CAPGO_KEEP_0__ のTCPポートをテストするconst port = await NetworkDiagnostics.testPort({ host: 'api.example.com', port: 443, timeoutMs: 3000,});
console.log(port.open, port.durationMs);Wi-Fi アクセス ポイントが標準以外のポート、MQTT、カスタムゲートウェイ、またはプライベートバックエンドをブロックしながら、通常のブラウジングを許可している場合に便利です。
__CAPGO_KEEP_0__ のWebSocket接続性をテストする
「テスト WebSocket 接続性」const socket = await NetworkDiagnostics.testWebSocket({ url: 'wss://ws.example.com/socket', timeoutMs: 5000,});
console.log(socket.open, socket.statusCode);プロキシやキャプティブ ポータルが HTTPS ページを許可するが、WebSocket アップグレード要求をブロックする場合に使用してください。
ダウンロード速度を測定
「ダウンロード速度を測定」const speed = await NetworkDiagnostics.testDownloadSpeed({ url: 'https://speed.example.com/5mb.bin', maxBytes: 5 * 1024 * 1024, timeoutMs: 30000,});
console.log(speed.mbps);独自の静的ファイルエンドポイントを使用して、結果がアプリが必要とするネットワークパスを反映するようにします。
パケット損失を推定
「パケット損失を推定」const loss = await NetworkDiagnostics.testPacketLoss({ mode: 'tcp', host: 'api.example.com', port: 443, count: 10, timeoutMs: 3000, intervalMs: 250,});
console.log(loss.lossPercent);App StoreとPlay Storeのアプリでは、RAW ICMP パINGが移植性が低いため、この方法はTCPまたはHTTPプローブを繰り返してアプリケーションレベルのパケット損失を測定します。
Web フェールバック
Web fallbackのセクション開発用にWeb実装を使用します。ブラウザでは、RAW TCPソケットを開くことはできず、URLチェックはCORSによって制限される可能性があります。iOSまたはAndroidのビルドを使用して、実際のサポート診断を行ってください。