Lompat ke Konten

Pengaturan Android & Verifikasi Backend

Pada Android, plugin ini menggunakan Standar Integritas Google Play API:

  • prepareIntegrityToken selama prepare()
  • requestStandardIntegrityToken untuk createAttestation() dan createAssertion()
  • Aplikasi Android yang didistribusikan melalui ekosistem Google Play
  • Jasa Google Play tersedia di perangkat
  • Integritas Play API diaktifkan untuk aplikasi Anda
  • Nomor proyek Google Cloud dikonfigurasi
  1. Aktifkan Integritas Play API di proyek Google Cloud Anda.
  2. Buka Console Play dan konfigurasi akses Integritas Play untuk aplikasi Anda.
  3. Sediakan cloudProjectNumber ke plugin.
capacitor.config.ts
plugins: {
AppAttest: {
cloudProjectNumber: '123456789012',
},
}

Anda juga dapat melewati cloudProjectNumber per panggilan dalam opsi metode.

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 adalah token Integrasi Play dan harus diurai di sisi server.

  1. Backend membuat kode satu kali challenge.
  2. Aplikasi memanggil createAttestation({ keyId, challenge }).
  3. Backend memanggil Google decodeIntegrityToken API.
  4. Backend memverifikasi setidaknya:
    • requestDetails.requestHash === base64url(SHA256(challenge))
    • appIntegrity.packageName sama dengan ID aplikasi Android Anda
    • appIntegrity.certificateSha256Digest mengandung tanda tangan sertifikat rilis Anda
    • kesimpulan integritas sesuai dengan kebijakan keamanan Anda

Perlindungan permintaan (createAssertion)

Judul bagian “Perlindungan permintaan (createAssertion)”
  1. Backend membuat token satu kali payload.
  2. Aplikasi memanggil createAssertion({ keyId, payload }).
  3. Backend memecahkan token dan memeriksa requestHash === base64url(SHA256(payload)).
  4. Menggunakan kebijakan integritas untuk mencegah ulang pemakaian (single-use + TTL).
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

Pendaftaran:

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

Pernyataan:

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

Lanjutkan dari Pengaturan Android & Verifikasi Backend

Judul Bagian “Lanjutkan dari Pengaturan Android & Verifikasi Backend”

Jika Anda menggunakan Pengaturan Android & Verifikasi Backend untuk merencanakan keamanan dan kinerja, hubungkannya dengan Menggunakan @capgo/capacitor-app-attest untuk kemampuan asli dalam Menggunakan @capgo/capacitor-app-attest, Enkripsi untuk detail implementasi dalam Enkripsi, Kepatuhan untuk detail implementasi di Kepatuhan, Capgo Scanner Keamanan untuk alur produk di Capgo Scanner Keamanan, dan Capgo Keamanan untuk alur produk di Capgo Keamanan.