Android Setup & Backend-Verifizierung
Einen Setup-Prompt mit den Installationsanweisungen und der vollständigen Markdown-Dokumentation für diesen Plugin kopieren.
Android-native-System verwendet
Abschnitt: Android-native-System verwendetBei Android wird dieses Plugin verwendet Google Play Integrity Standard API:
prepareIntegrityTokenwährendprepare()requestStandardIntegrityTokenfürcreateAttestation()undcreateAssertion()
Anforderungen
Abschnitt: Anforderungen- Android-App wird über das Google Play-Ökosystem verteilt
- Google Play-Dienste sind auf dem Gerät verfügbar
- Play Integrity API ist für Ihre App aktiviert
- Google Cloud-Projekt-Nummer konfiguriert
Google einrichten
Abschnitt mit dem Titel „Google einrichten“- Aktivieren Play Integrity API in Ihrem Google Cloud-Projekt. Öffnen Sie das Play Console und konfigurieren Sie den Zugriff auf Play Integrity für Ihre App.
- Bereitstellen
- dem Plugin.
cloudProjectNumber__CAPGO_KEEP_0__-Konfiguration
Abschnitt mit dem Titel „Capacitor-Konfiguration“
Capacitor.config.tsplugins: { AppAttest: { cloudProjectNumber: '123456789012', },}Sie können auch einen Wert übergeben cloudProjectNumber in der Methodeoption pro Aufruf.
Client-Fluss
Abschnitt mit dem Titel “Client-Fluss”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 ist ein Play-Integritäts-Token und muss serverseitig entschlüsselt werden.
Hintergrundablauf (Android)
Abschnitt mit dem Titel “Hintergrundablauf (Android)”Registrierung (createAttestation)
Abschnitt mit dem Titel “Registrierung (createAttestation)”- Der Hintergrund erstellt einen einmaligen Token
challenge. - App-Anrufe
createAttestation({ keyId, challenge }). - Hintergrundanrufe bei Google
decodeIntegrityTokenAPI. - Hintergrund verifiziert mindestens:
requestDetails.requestHash === base64url(SHA256(challenge))appIntegrity.packageNameentspricht Ihrer Android-Anwendung-IdappIntegrity.certificateSha256Digestenthält Ihren Release-Signierungs-Zertifikats-Digest- Integritätsurteile entsprechen Ihrer Sicherheitspolitik
Anfrage-Schutz (createAssertion)
Abschnitt mit dem Titel “Anfrage-Schutz (createAssertion)”- Hintergrund erstellt eine einmalige
payload. - App-Anrufe
createAssertion({ keyId, payload }). - Hintergrund entschlüsselt Token und überprüft
requestHash === base64url(SHA256(payload)). - Verhindere Wiedergabeprävention (eine Verwendung + TTL) und Integritätsurteilsrichtlinie.
Android-Schema
Abschnitt mit dem Titel “Android-Schema”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 policyMinimaler Backend-Payload-Vertrag
Abschnitt mit dem Titel “Minimaler Backend-Payload-Vertrag”Registrierung:
{ "platform": "android", "format": "google-play-integrity-standard", "keyId": "string", "challenge": "string", "token": "string"}Behauptung:
{ "platform": "android", "format": "google-play-integrity-standard", "keyId": "string", "payload": "string", "token": "string"}