メインコンテンツにスキップ

はじめに

GitHub

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-diagnostics
npx 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.

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、プロキシ、またはキャプティブ ポータル動作によって隠される可能性があります。このプラグインは、ネイティブ ネットワーキングを使用するため、異なるものです。

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のビルドを使用して、実際のサポート診断を行ってください。