Configuración de Android & Verificación del Servidor
Copie un prompt de configuración con los pasos de instalación y la guía markdown completa para este plugin.
Se utiliza el sistema nativo de Android
Sección titulada “Se utiliza el sistema nativo de Android”En Android, este plugin utiliza El estándar de integridad de Google Play API:
prepareIntegrityTokenduranteprepare()requestStandardIntegrityTokenparacreateAttestation()ycreateAssertion()
Requisitos
Sección titulada “Requisitos”- La aplicación de Android distribuida a través del ecosistema de Google Play
- Los servicios de Google Play disponibles en el dispositivo
- Juega con integridad API habilitada para tu aplicación
- Número de proyecto de Google Cloud configurado
Configuración de Google
Sección titulada “Configuración de Google”- Habilitar Integridad de Juega con API en tu proyecto de Google Cloud.
- Abre la consola de Juega y configura el acceso de integridad de Juega para tu aplicación.
- Proporciona
cloudProjectNumberal plugin.
Capacitor config
Sección titulada “Capacitor config”plugins: { AppAttest: { cloudProjectNumber: '123456789012', },}También puedes pasar cloudProjectNumber por llamada en opciones de método.
Flujo del cliente
Sección titulada “Flujo del cliente”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 es un token de integridad de Play y debe ser descodificado en el lado del servidor.
Flujo de backend (Android)
Sección titulada “Flujo de backend (Android)”Registro (createAttestation)
Sección titulada “Registro (createAttestation)”- Backend crea uno de uso único
challenge. - La aplicación llama
createAttestation({ keyId, challenge }). - El backend llama a Google
decodeIntegrityTokenAPI. - El backend verifica al menos:
requestDetails.requestHash === base64url(SHA256(challenge))appIntegrity.packageNamees igual a su identificador de aplicación de AndroidappIntegrity.certificateSha256Digestcontiene el digest de certificado de firma de liberación- los veredictos de integridad coinciden con su política de seguridad
Protección de solicitudes (createAssertion)
Sección titulada “Protección de solicitudes (createAssertion)”- Backend crea uno de uso único
payload. - La aplicación llama
createAssertion({ keyId, payload }). - Backend descodifica el token y verifica
requestHash === base64url(SHA256(payload)). - Impone la prevención de retransmisiones (uso único + TTL) y política de veredicto de integridad.
Esquema de Android
Sección titulada “Esquema de 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 policyContrato de pago de backend mínimo
Sección titulada “Contrato de pago de backend mínimo”Registro:
{ "platform": "android", "format": "google-play-integrity-standard", "keyId": "string", "challenge": "string", "token": "string"}Afirmación:
{ "platform": "android", "format": "google-play-integrity-standard", "keyId": "string", "payload": "string", "token": "string"}Sigue adelante desde Configuración de Android & Verificación de Backend
Sección titulada “Sigue adelante desde la configuración de Android y la verificación del backend”Si estás utilizando Configuración de Android y verificación del backend para planificar la seguridad y la conformidad, conecta con Usando @capgo/capacitor-app-attest para la capacidad nativa en Usando @capgo/capacitor-app-attest, Cifrado para el detalle de implementación en Cifrado, Conformidad para el detalle de implementación en Conformidad, Capgo Escáner de Seguridad para el flujo de trabajo del producto en Capgo Escáner de Seguridad, y Capgo Seguridad para el flujo de trabajo del producto en Capgo Seguridad.