Skip to content

시작하기

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.

__CAPGO_KEEP_1__

__CAPGO_KEEP_2__
npm install @capgo/capacitor-network-diagnostics
npx cap sync

__CAPGO_KEEP_3__

__CAPGO_KEEP_4__
import { NetworkDiagnostics } from '@capgo/capacitor-network-diagnostics';

__CAPGO_KEEP_5__

__CAPGO_KEEP_6__

runDiagnostics __CAPGO_KEEP_0__

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, 프록시, 또는 캡티브 포털 동작에 의해 숨겨질 수 있지만 이 플러그인은 네이티브 네트워킹을 사용합니다.

TCP 포트 테스트

클립보드 복사
const port = await NetworkDiagnostics.testPort({
host: 'api.example.com',
port: 443,
timeoutMs: 3000,
});
console.log(port.open, port.durationMs);

웹소켓 연결 테스트

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 ping이 포팅되지 않습니다. 이 방법은 TCP 또는 HTTP 프로브를 반복하여 애플리케이션 수준의 패킷 손실을 측정합니다.

웹 구현은 개발 목적으로 설계되었습니다. 브라우저는 raw TCP 소켓을 열 수 없으며 CORS로 URL 확인이 제한될 수 있습니다. iOS 또는 Android 빌드를 사용하여 실제 지원 진단을 위해.