Verifique qualquer ID, em qualquer parte do mundo.
Verifique um passaporte, cartão de cidadão, carta de condução ou título de residência de qualquer país. Mais de 14.000 documentos, veredito em menos de 2 segundos, $0.15 por verificação, 500 grátis/mês.
Confiado por mais de 2.000 organizações em todo o mundo.
Cobertura global
Mais de 14.000 documentos. Mais de 220 países.
DNI espanhol, My Number japonês, passaporte do Reino Unido. Novos documentos são adicionados todos os meses,
o mesmo $0.15 por verificação, o mesmo formato de veredito, a mesma resposta em menos de 2 segundos.
Como funciona
Do registo ao utilizador verificado em quatro passos.
Passo 01
Crie o fluxo de trabalho
Escolha as verificações que pretende, ID, prova de vida, correspondência facial, sanções, morada, 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
Integre
Integre nativamente com os nossos SDKs para 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 stack.
Passo 03
O utilizador passa pelo fluxo
A Didit aloja a câmara, as indicações de iluminação, a transição para o telemóvel e a acessibilidade. Enquanto o utilizador está no fluxo, pontuamos mais de 200 sinais de fraude em tempo real e verificamos cada campo em relação a 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 a pedido. Ou abra a consola para inspecionar cada sessão, cada sinal e gerir os casos à sua maneira.
Criado para developers · Criado contra a fraude · Aberto por design
Seis capacidades. Uma feature flag. ID_VERIFICATION .
Cada capacidade abaixo é um toggle no mesmo módulo. Sem níveis de upsell, sem SKUs separados, sem chamadas adicionais. Ative-os por fluxo de trabalho na consola, ou passe-os inline quando chamar o endpoint autónomo.
Mais de 220 países. Mais de 14.000 tipos de documentos.
Passaportes, cartões de cidadão, cartas de condução, títulos de residência. Mais de 130 idiomas, mais de 50 sistemas de escrita (Latim, Árabe, Cirílico, CJK, Devanagari, Hebraico, Tailandês, Georgiano). Novos documentos adicionados todos os meses. Controlo de subtipos por país, aceite o Indiana Operator e o New York Enhanced separadamente, se a política o exigir.
Supported documents
Updated this month
Live
220+
Countries
14,000+
Document types
130+
Languages
50+
Scripts
PassportID cardDriver's licenseResidence permit
🇪🇸ES
🇺🇸US
🇧🇷BR
🇩🇪DE
🇲🇽MX
🇮🇳IN
🇫🇷FR
🇬🇧GB
🇯🇵JP
🇳🇬NG
🇦🇪AE
🇸🇬SG
02 · Extração de dados
Campos visuais, MRZ e código de barras, verificados.
Todos os campos visuais, MRZ (zona de leitura ótica) e de código de barras extraídos numa só passagem. Os três são verificados antes de a resposta sair do nosso sistema. As inconsistências surgem como avisos para que possa encaminhar o caso para revisão manual.
Personal data
OCR · MRZ · Barcode
First name
Olivia
Matches with Data provided via API: Olivia
Last name
Roy
Date of birth
28/06/1971
Document type
Passport
Issuing state
Spain🇪🇸
Document number
3EB8726CC6E0F979
03 · Autenticidade
Documento real. Retrato intacto. Sem captura de ecrã.
Correspondência de modelo com a base de dados certificada. Deteção de hologramas e microimpressões. Verificação da integridade do retrato. A deteção de vivacidade do documento impede quatro vetores de ataque comuns, capturas de ecrã, fotos de telemóvel, cópias impressas e substituições de retrato em documentos que, de outra forma, seriam reais.
Document authenticity
Authentic
Document portrait
Live capture
Similarity 94%
Template match
Hologram detected
Microprint intact
Document liveness passed
04 · Qualidade da captura
Rejeite desfocagem e brilho antes da revisão.
Foco, brilho e resolução pontuados de 0 a 100 por submissão, mais uma pontuação geral ponderada. Cantos fora do enquadramento e lados sobreexpostos assinalados explicitamente. Limiares ajustáveis rejeitam capturas de baixa qualidade logo à partida, para que nunca cheguem à sua fila de revisão manual.
Capture quality
Capture ready
Hold steady
Overall score
91/100
Focus92
Brightness88
Resolution95
05 · Política de risco
Decida. Reveja. Aprove. Por risco. Por aplicação.
Cada categoria de risco, utilizador duplicado, MRZ inválido, inconsistência de dados, baixa vivacidade do documento, mapeia para recusar, rever ou aprovar. Ajuste a política por aplicação, país e tipo de documento. Os gatilhos de recusa automática (expirado, bloqueado, não suportado) são aplicados independentemente das suas definições.
Risk policy
5 categories
Risk categoryAction
Duplicated user
Decline
Invalid MRZ
Review
Data inconsistency
Review
Invalid validation
Decline
Low document liveness
Approve
06 · KYC contínuo
Documentos expiram. Detete antes que o regulador o faça.
Monitorizamos a validade de cada documento que armazena. Quando um expira, o estado KYC do utilizador muda automaticamente e enviamos-lhe uma notificação via webhook. Sem tarefas em lote, sem sprints trimestrais de re-onboarding, a atualização do KYC é contínua e mantém-no em conformidade com a Diretiva AML.
Document monitoring
Auto-tracks expiry · webhook on status change
Live
1,284
Active
47
Expiring soon
9
Expired
Webhook fired · usr_9f01a3c moved to Kyc expired12s ago
Ausr_a8c4f02Passport12 Mar 2027Active
Musr_4d2b6e1ID card08 Jun 2026Expiring
Lusr_9f01a3cDriving license21 Sep 2025KYC expired
Integrar
Dois endpoints. O mesmo JSON. O mesmo preço.
Crie uma sessão quando quiser que a nossa UI alojada trate da captura, ou chame o endpoint autónomo quando já tiver a imagem. Ambos devolvem o mesmo relatório de id_verification.
Implemente a Verificação de Identidade com um único prompt.
Cole o bloco abaixo no Claude Code, Cursor, Codex, Devin, Aider ou Replit Agent. Preencha o placeholder my_stack com o seu framework, linguagem e caso de uso. O agente configura o Didit, constrói o fluxo de trabalho com a Verificação de Identidade ativada, liga o webhook e implementa.
didit-integration-prompt.md
# Didit ID Verification — integrate in 5 minutes
You are integrating Didit's ID Verification module into <my_stack>. Follow
these steps exactly. Every URL, header, and enum value below is canonical —
do not paraphrase or "improve" them.
## 1. Provision an account
- Sign up: https://business.didit.me (no credit card required).
- Or provision programmatically: POST https://apx.didit.me/auth/v2/programmatic/register/
(returns an API key bound to the workspace + application).
## 2. Two integration paths — pick one
### Path A — Workflow Builder (hosted UI)
Best when you want Didit to handle camera, lighting cues, retries,
mobile handoff, and accessibility for you.
1. Create a workflow that contains the ID_VERIFICATION feature:
POST https://verification.didit.me/v3/workflows/
Authorization header: x-api-key: <your-api-key>
Body: workflow_label, features array with the single entry
{ feature: "ID_VERIFICATION" } (UPPERCASE — strict enum)
2. Create a verification session for an end user:
POST https://verification.didit.me/v3/session/
Body: workflow_id (from step 1), vendor_data (your own user id).
Response: session_url — redirect the user to it.
3. Listen for webhook callbacks (see "Webhooks" below).
### Path B — Standalone server-to-server API
Best when you already have the document image (mobile SDK capture, native
onboarding app, reseller pipeline).
POST https://verification.didit.me/v3/id-verification/
Content-Type: multipart/form-data
Body fields:
- front_image (required, file)
- back_image (optional, file)
- vendor_data (optional string, your user id)
Response: JSON report with extracted fields, image quality scores,
warnings array, and the verdict.
## 3. Webhooks (Path A only — Path B returns synchronously)
- Register a webhook destination once via
POST https://verification.didit.me/v3/webhook/destinations/
Body: url, subscribed_events: ["session.verified", "session.review_started",
"session.declined", "kyc_expired"]
- Response includes secret_shared_key — store it.
- Every webhook delivery carries an X-Signature-V2 header you MUST verify
before trusting the payload. HMAC-SHA256 verification MUST run against the raw body bytes (the raw payload as Didit sent it) BEFORE any JSON parsing — re-serialising the parsed body changes whitespace and key order, which invalidates the signature.Algorithm:
1. sortKeys(payload) recursively
2. shortenFloats (truncate trailing zeros after the decimal point)
3. JSON.stringify the result
4. HMAC-SHA256 with the secret_shared_key
5. Hex-encode, compare to the X-Signature-V2 header.
## 4. Reading the report (both paths return the same shape)
The id_verification object includes:
- status: "Approved" | "Declined" | "In Review" | "Expired" | "Not Finished"
- document_type: "Passport" | "Identity Card" | "Driver's License" | "Residence Permit" | null
- document_number, personal_number
- front_image, back_image, portrait_image (signed URLs, expire in 1 hour)
- date_of_birth (YYYY-MM-DD), age (number)
- expiration_date, date_of_issue (YYYY-MM-DD)
- issuing_state, issuing_state_name (ISO 3166-1 alpha-3 + display name)
- first_name, last_name, full_name
- gender ("M" | "F" | "U"), nationality (ISO 3166-1 alpha-3)
- address, formatted_address, parsed_address (street_1, street_2, city,
region, postal_code, geometry { lat, lng })
- front_image_quality_score / back_image_quality_score (focus, brightness,
resolution, overall, each 0-100)
- warnings: Array<{ risk, log_type, short_description, long_description }>
## 5. Hard rules — do not change
- Base URL for /v3/* endpoints is verification.didit.me (NOT apx.didit.me).
- Feature enum is UPPERCASE: ID_VERIFICATION, LIVENESS, FACE_MATCH, AML, IP_ANALYSIS.
- Auth header is x-api-key (lowercase, hyphenated).
- Webhook signature header is X-Signature-V2 (NOT X-Signature).
- Always verify webhook signatures before trusting payload data.
- Status casing matches exactly: "Approved", "Declined", "In Review",
"Expired", "Not Finished" (title-cased, space-separated).
## 6. Pricing reference (public)
- Path A bundled in a full KYC workflow: $0.33 per session
- Path B standalone /v3/id-verification/ call: $0.15 per call
- 500 free verifications every month, forever, on every account.
## 7. Verify your integration
- Sandbox starts on signup at https://business.didit.me — no separate flag.
- Test docs: deterministic synthetic IDs returned in sandbox.
- Switch to live: flip the application's environment toggle in console.
When in doubt: https://docs.didit.me/core-technology/id-verification/overview
Conformidade desde a conceção
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 lançar verificações num novo país, basta ativar um botão. Mais de 220 países ativos, 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.
Tipos de documentos de identidade na base de dados certificada.
<0s
Inferência de ponta a ponta por verificação.
$0.00
Por verificação de ID autónoma. 500 gratuitas todos os meses.
Três níveis, uma tabela de preços
Comece grátis. Pague por utilização. Expanda para Enterprise.
500 verificações gratuitas todos os meses, para sempre. Pague à medida que usa para produção. Contratos personalizados, residência de dados e SLAs (Acordos de Nível de Serviço) 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 grátis → pague apenas quando uma verificação for executada → desbloqueie o Enterprise para um contrato personalizado, SLA ou residência de dados.