컨텐츠로 바로가기

안드로이드 설정 및 백엔드 확인

Android에서 이 플러그인은 Google Play 정직성 표준 API:

  • prepareIntegrityToken 동안 prepare()
  • requestStandardIntegrityToken 위해 createAttestation()createAssertion()
  • 구글 플레이 스토어를 통해 배포되는 안드로이드 앱
  • 장치에 구글 플레이 서비스가 사용 가능합니다.
  • 앱에 대해 플레이 인TEGRITY API이 활성화되어 있습니다.
  • 구글 클라우드 프로젝트 번호가 구성되어 있습니다.
  1. 활성화 앱에 대해 플레이 인TEGRITY API 구글 클라우드 프로젝트에서 앱에 대한 플레이 인TEGRITY 접근을 구성하세요.
  2. 플레이 콘솔을 열고 앱에 대한 플레이 인TEGRITY 접근을 구성하세요.
  3. 제공 cloudProjectNumber 플러그인에 대한 접근을 허용합니다.
capacitor.config.ts
plugins: {
AppAttest: {
cloudProjectNumber: '123456789012',
},
}

또한 옵션에서 메서드 호출당 cloudProjectNumber 클라이언트 흐름

제목 "클라이언트 흐름"

클립보드에 복사
import { AppAttest } from '@capgo/capacitor-app-attest';
const { keyId } = await AppAttest.prepare({
cloudProjectNumber: '123456789012',
});
const attestation = await AppAttest.createAttestation({
keyId,
challenge: 'backend-registration-challenge',
});
const assertion = await AppAttest.createAssertion({
keyId,
payload: 'backend-request-payload',
});

token 백엔드 워크플로우 (Android)

등록 (createAttestation)

등록 (createAttestation)
  1. 백엔드가 일회용 challenge.
  2. 앱이 호출 createAttestation({ keyId, challenge }).
  3. 백엔드가 Google decodeIntegrityToken API.
  4. 백엔드가 최소한의 검증:
    • requestDetails.requestHash === base64url(SHA256(challenge))
    • appIntegrity.packageName Android 애플리케이션 ID와 일치
    • appIntegrity.certificateSha256Digest 릴리즈 서명 인증서 해시 포함
    • 보안 정책에 따라서完整성 판단

요청 보호 (createAssertion)

Request protection (createAssertion)
  1. 백엔드가 일회용 토큰을 생성합니다. payload.
  2. 앱이 요청합니다. createAssertion({ keyId, payload }).
  3. 백엔드가 토큰을 해독하고 검사합니다. requestHash === base64url(SHA256(payload)).
  4. 재생방지 (단용 + TTL) 및 무결성 판단 정책을 강제합니다.

Android 스키마

Android 스키마
sequenceDiagram
participant App as Android App
participant Plugin as AppAttest plugin
participant PlaySDK as Play Integrity SDK
participant BE as Backend
participant Google as decodeIntegrityToken API
App->>Plugin: prepare(cloudProjectNumber)
Plugin->>PlaySDK: prepareIntegrityToken()
PlaySDK-->>Plugin: provider handle (keyId)
BE->>App: one-time challenge
App->>Plugin: createAttestation(keyId, challenge)
Plugin->>PlaySDK: requestStandardIntegrityToken(requestHash)
PlaySDK-->>Plugin: integrity token
Plugin-->>App: token + platform + format + keyId
App->>BE: token + challenge + keyId
BE->>Google: decodeIntegrityToken(token)
Google-->>BE: decoded payload
BE->>BE: verify requestHash + app identity + verdicts
BE->>App: one-time payload
App->>Plugin: createAssertion(keyId, payload)
Plugin->>PlaySDK: requestStandardIntegrityToken(requestHash)
PlaySDK-->>Plugin: integrity token
App->>BE: token + payload + keyId
BE->>Google: decodeIntegrityToken(token)
Google-->>BE: decoded payload
BE->>BE: verify requestHash + replay policy

최소 백엔드 페이로드 계약

등록:

클립보드에 복사

{
"platform": "android",
"format": "google-play-integrity-standard",
"keyId": "string",
"challenge": "string",
"token": "string"
}

보장:

{
"platform": "android",
"format": "google-play-integrity-standard",
"keyId": "string",
"payload": "string",
"token": "string"
}

안드로이드 설정 및 백엔드 검증에서 계속하기

안드로이드 설정 및 백엔드 검증에서 계속하기

Capgo를 사용 중이라면 안드로이드 설정 및 백엔드 검증 보안 및 규정 준수 계획을 위해 연결하세요. Using @capgo/capacitor-app-attest Using @capgo/capacitor-app-attest 암호화 암호화 규정 준수 Compliance 구현 세부 사항에 대해 Capgo 보안 스캐너 Capgo 보안 스캐너의 제품 워크플로에 대해, 그리고 Capgo 보안 Capgo 보안의 제품 워크플로에 대해, 그리고