Controlo de idade sem upload de ID. Verifique com uma selfie. Recorra a um documento apenas quando necessário.
Estime a idade a partir de uma selfie passiva por $0.10. O fallback do documento é acionado apenas em casos limítrofes. Pronto para o UK Online Safety Act e France SREN. 500 verificações gratuitas todos os meses.
Confiado por mais de 2.000 organizações em todo o mundo.
UK Ofcom · France SREN · EU DSA
Verifique a idade em 1 segundo. Documento apenas quando necessário.
Forçar cada visitante a fazer um upload de documento reduz as taxas de conclusão em 25-40%.
O fluxo adaptativo da Didit executa primeiro a Estimativa de Idade e só encaminha a
cauda limítrofe para o fallback do documento. Veredito de selfie em menos de 2 segundos, $0.10
por verificação, custo combinado perto de $0.115 por utilizador. 500 verificações gratuitas todos os
meses.
Como funciona
Do registo ao utilizador verificado em quatro passos.
Passo 01
Criar o fluxo de trabalho
Escolha as verificações que deseja — ID, prova de vida, correspondência facial, sanções, endereço, idade, telefone, e-mail, perguntas personalizadas. Arraste-as para um fluxo no painel de controlo, ou publique o mesmo fluxo na nossa API. Crie ramificações com base em condições, execute testes A/B, sem necessidade de código.
Passo 02
Integrar
Incorpore nativamente com o nosso SDK Web, iOS, Android, React Native ou Flutter. Redirecione para uma página alojada. Ou simplesmente envie um link ao seu utilizador — por e-mail, SMS, WhatsApp, em qualquer lugar. Escolha o que melhor se adapta à sua pilha.
Passo 03
O utilizador passa pelo fluxo
A Didit aloja a câmara, as indicações de iluminação, a transição móvel e a acessibilidade. Enquanto o utilizador está no fluxo, pontuamos mais de 200 sinais de fraude em tempo real e verificamos cada campo contra fontes de dados autorizadas. Resultado em menos de dois segundos.
Passo 04
Recebe os resultados
Webhooks assinados em tempo real mantêm a sua base de dados sincronizada no momento em que um utilizador é aprovado, recusado ou enviado para revisão. Consulte a API sob demanda. Ou abra a consola para inspecionar cada sessão, cada sinal e gerir os casos à sua maneira.
Construído para controlo de idade · Preço de infraestrutura
Seis capacidades. $0.115 misturado por utilizador.
Um fluxo de trabalho adaptativo executa a cascata "selfie-first" e só escala a minoria limítrofe. Ajuste a banda limítrofe por fluxo de trabalho, adicione regras de idade por país e deixe a Didit fazer o encaminhamento.
Um fotograma, sem desafio de movimento, sem upload de documento. Veredito em menos de 2 segundos em Android de nível básico, $0.10 por verificação. A resposta de dados mínimos ao UK Online Safety Act e France SREN.
Veredito em menos de 2 segundos em Android de nível básico.
02 · Encaminhamento de banda limítrofe
Ajuste a banda. A Didit encaminha o resto.
Defina a banda limítrofe por fluxo de trabalho. Aprovação clara e reprovação clara terminam na selfie; a banda escala para o fallback do documento. Edite os pontos de corte no Construtor de Fluxos de Trabalho sem código, sem necessidade de reimplantar.
Apenas a cauda limítrofe carrega um documento. Passaportes, cartões de identidade nacionais, cartas de condução, autorizações de residência com Reconhecimento Ótico de Caracteres (OCR) completo e análise de Zona Legível por Máquina (MRZ). Cerca de 10% do tráfego típico atinge esta etapa.
Mais de 14.000 documentos. Apenas quando necessário.
$0.15 / check
PassportMRZ + página de fotografia
Cartão de cidadãoFrente + verso, OCR
Carta de conduçãoRegras por estado nos EUA, CA, AU
Autorização de residênciaSchengen + UK BRP
Mais de 220 países · Mais de 48 idiomas~10% tráfego
04 · Regras de idade por país
Beber aos 21 nos EUA. 18 na UE. 19 na Coreia.
Defina a idade mínima por país, com substituições a nível estadual onde for relevante (Mississippi 21, Alabama 19, EUA padrão 18). O fallback do documento valida automaticamente a data de nascimento em relação à regra do país emissor.
Substituições a nível estadual (Mississippi 21, Alabama 19) incluídas.
05 · Preparação para reguladores
Ofcom do Reino Unido, CNIL da França, DSA da UE, JuSchG da Alemanha.
Construído para a barra de garantia de idade altamente eficaz. O Tesoro e o SEPBLAC de Espanha atestaram formalmente que o fluxo remoto da Didit é mais seguro do que a verificação presencial — atualmente o único atestado governamental de um estado-membro da UE do seu tipo. O pacote de auditoria inclui iBeta Nível 1 PAD, ISO/IEC 27001, SOC 2 Tipo 1.
Reino Unido Ofcom (OSA)Estimation or documentShips
França CNIL / Arcom (SREN)Estimation or documentShips
DSA da UE — VLOPsProporcional ao riscoShips
Alemanha JuSchGDocumento ou KYCShips
Atestado Tesoro / SEPBLAC incluído no pacote de auditoria.
06 · Preços públicos
$0.10 selfie. $0.15 document. Only when needed.
A Estimativa de Idade a $0.10 cobre os ~90% que são aprovados com uma selfie. A verificação de documento a $0.15 é acionada apenas para a minoria limítrofe de ~10%. O custo combinado fica perto de $0.115 por utilizador. 500 verificações gratuitas todos os meses, para sempre.
200OKestado Aprovado · Em Revisão · Recusado · Não Concluído
Mesma forma no webhook assinado. Verifique X-Signature-V2 primeiro.documentos →
Integração pronta para agente
Envie a verificação de idade num único prompt.
Cole no Claude Code, Cursor, Codex, Devin, Aider ou Replit Agent. Preencha a sua stack. O agente constrói o fluxo de trabalho adaptativo, abre a sessão, liga o webhook e envia em cinco minutos.
didit-integration-prompt.md
You are integrating Didit's Age Verification recipe into <my_stack>. Selfie-first age estimation with an adaptive document fallback for the borderline tail. One Didit workflow. Two real endpoints.
1. Verify age on a selfie. ONE call to the Sessions API runs Age Estimation + Passive Liveness on the same passive frame.
2. Fall back to a document check ONLY when the estimate sits in the borderline band you define. Same Sessions API workflow handles the fallback automatically.
Bundle pricing (public):
- Age Estimation: $0.10 per check (Sessions API or standalone)
- ID Verification fallback: $0.15 per check, only when triggered
- Typical blended cost lands near $0.115 per user (~90% finish on the selfie, ~10% touch the document fallback)
- First 500 verifications free every month, forever
PRE-REQUISITES
- Production API key from https://business.didit.me (sandbox key in 60s, no card).
- Webhook endpoint with Hash-based Message Authentication Code (HMAC) SHA-256 verification using the X-Signature-V2 header and your webhook secret.
- A workflow_id from the Workflow Builder. The workflow must contain the AGE_ESTIMATION feature, and (recommended) the ID_VERIFICATION feature with adaptive_id_verification enabled so the borderline tail routes through automatically.
STEP 1 — Build the adaptive workflow once
POST https://verification.didit.me/v3/workflows/
Headers:
x-api-key: <your api key>
Content-Type: application/json
Body:
{
"workflow_label": "age_gate_uk_fr",
"features": [
{ "feature": "AGE_ESTIMATION" },
{ "feature": "ID_VERIFICATION" }
],
"age_estimation_decline_threshold": 18,
"face_liveness_score_decline_threshold": 30,
"adaptive_id_verification": true
}
Notes:
- "AGE_ESTIMATION" and "ID_VERIFICATION" are exact, case-sensitive feature names.
- age_estimation_decline_threshold defaults to 18; set 21 for US alcohol, 19 for South Korea, etc.
- adaptive_id_verification = true tells Didit to invoke the document fallback automatically when the estimate sits inside the borderline band.
STEP 2 — Open an age-verification session per user
POST https://verification.didit.me/v3/session/
Headers:
x-api-key: <your api key>
Content-Type: application/json
Body:
{
"workflow_id": "<the workflow_id from step 1>",
"vendor_data": "<your internal user id>",
"callback": "https://<your-app>/age-gate/callback",
"metadata": {
"purpose": "age_gate",
"surface": "<the page or feature being gated>"
}
}
Response: 201 Created with the hosted session_url. Redirect the user to it. The hosted flow opens the front camera, captures one passive frame, runs Age Estimation + Passive Liveness in sub-2-seconds, and either returns a verdict or routes the user into the document fallback automatically.
STEP 3 — Read the signed webhook on session completion
Didit POSTs to your callback. Session statuses are exact Title Case With Spaces.
Body (excerpted for an Age Estimation only finish):
{
"session_id": "<uuid>",
"vendor_data": "<your user id>",
"status": "Approved",
"liveness": {
"status": "Approved",
"method": "PASSIVE",
"score": 92,
"age_estimation": 27.3,
"warnings": []
}
}
Body (excerpted when the document fallback fired):
{
"session_id": "<uuid>",
"vendor_data": "<your user id>",
"status": "Approved",
"liveness": { "status": "Approved", "age_estimation": 17.9, "warnings": [{ "code": "AGE_NOT_DETECTED" }] },
"id_verification": {
"status": "Approved",
"date_of_birth": "1998-03-21",
"age": 27,
"document_type": "Passport",
"issuing_state": "GBR"
}
}
Verify X-Signature-V2 BEFORE trusting the body — HMAC SHA-256 of the raw bytes with your webhook secret.
Session status enum (exact case): Approved | Declined | In Review | Resubmitted | Expired | Not Finished | Kyc Expired | Abandoned.
Warning catalog:
- AGE_BELOW_MINIMUM estimated or computed age below the threshold
- AGE_NOT_DETECTED unable to estimate age (lighting / quality)
- LOW_LIVENESS_SCORE passive-liveness score below threshold
- NO_FACE_DETECTED no face in the capture
- LIVENESS_FACE_ATTACK presentation attack suspected
- POSSIBLE_DUPLICATED_FACE same face previously verified
STEP 4 — Branch your surface on the final verdict
Approved → grant access to the gated surface.
Declined → render the regulator-required age-gate notice.
In Review → hold; an analyst case is open in the Business Console.
Not Finished → user abandoned; safe to re-prompt.
STEP 5 — Alternate path (server-to-server, when you already have the selfie)
POST https://verification.didit.me/v3/age-estimation/
Headers:
x-api-key: <your api key>
Body (multipart/form-data):
user_image <single passive selfie>
age_estimation_decline_threshold 18 (optional, integer)
face_liveness_score_decline_threshold 30 (optional, integer)
Branch on the borderline band yourself, then optionally call:
POST https://verification.didit.me/v3/id-verification/
Body (multipart/form-data):
front_image <required>
back_image <optional>
vendor_data <optional, your user id>
This path is useful for native onboarding apps that capture the selfie locally.
CONSTRAINTS
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: AGE_ESTIMATION, ID_VERIFICATION, LIVENESS, FACE_MATCH, AML, IP_ANALYSIS.
- Method enum is UPPERCASE: PASSIVE, FLASHING, ACTIVE_3D.
- Auth header is x-api-key (lowercase, hyphenated).
- Webhook signature header is X-Signature-V2 (NOT X-Signature).
- Status casing matches exactly: Approved, Declined, In Review, Expired, Not Finished, Resubmitted, Kyc Expired, Abandoned.
- Reference image URLs are signed and expire in 60 minutes. Store only the verdict + score; never the biometric media unless retention is explicitly enabled for fraud defence.
- 200+ fraud signals are evaluated on every session at no extra cost — surface the score via the session decision payload, do not re-query.
WEBHOOK EVENT NAMES
- Sessions: status changes flow through the standard session webhook.
- Verify X-Signature-V2 on every payload.
Read the docs:
- https://docs.didit.me/core-technology/age-estimation/overview
- https://docs.didit.me/sessions-api/create-session
- https://docs.didit.me/integration/webhooks
Start free at https://business.didit.me — sandbox key in 60 seconds, 500 verifications free every month, no credit card.
Precisa de mais contexto? Consulte a documentação completa do módulo.docs.didit.me →
Conforme por design
Abra um novo país com um clique. Nós fazemos o trabalho difícil.
Abrimos as subsidiárias locais, garantimos as licenças, realizamos os testes de penetração, obtemos as certificações e alinhamos com cada nova regulamentação. Para enviar verificações num novo país, basta ativar um botão. Mais de 220 países em funcionamento, auditados e testados trimestralmente — o único fornecedor de identidade que um governo de um estado membro da UE formalmente considerou mais seguro do que a verificação presencial.
Custo combinado por utilizador — selfie mais o fallback de documento de 10% na fronteira.
~90%
Dos utilizadores terminam apenas com a selfie passiva — sem upload de documento.
<0s
Faixa etária devolvida por sessão em Android de nível básico.
0
Verificações gratuitas todos os meses, para sempre.
Três níveis, uma lista de preços
Comece gratuitamente. Pague por uso. Escale para Enterprise.
500 verificações gratuitas todos os meses, para sempre. Pagamento conforme o uso para produção. Contratos personalizados, residência de dados e SLAs (Service Level Agreements) no Enterprise.
Grátis
Grátis
$0 / mês. Não é necessário cartão de crédito.
Pacote KYC gratuito (Verificação de ID + Prova de Vida Passiva + Correspondência Facial + Análise de Dispositivo e IP) — 500 / mês, todos os meses
Comece gratuitamente → pague apenas quando uma verificação for executada → desbloqueie o Enterprise para um contrato personalizado, SLA ou residência de dados.