Cartão Anti-falsificação da Indonésia
Use o algoritmo de aprendizado profundo para detectar se o rosto no certificado é PS, se o certificado é impresso, certificado de ataque de repetição, e a desfocagem do certificado, a iluminação do certificado
Exemplo de código:
curl --location --request POST 'https://api.ekycpro.com/v1/id_card/antifake' \--header 'Content-Type: application/x-www-form-urlencoded' \--header 'X-API-Key: AbcdEfgh' \--data-urlencode 'img=BASE64_ENCODE_VALUE'
Resposta para o rosto de entrada é PS
{ "status": "OK", "message": { "blur": { "isBlur": "no", "score": 0 }, "ps": { "isPs": "yes", "score": 95 }, "print": { "isPrint": "no", "score": 1 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para o rosto do cartão de entrada não é PS
{ "status": "OK", "message": { "blur": { "isBlur": "no", "score": 0 }, "ps": { "isPs": "no", "score": 8 }, "print": { "isPrint": "no", "score": 1 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para o cartão de entrada é uma imagem desfocada
{ "status": "OK", "message": { "blur": { "isBlur": "yes", "score": 61 }, "ps": { "isPs": "no", "score": 8 }, "print": { "isPrint": "no", "score": 1 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para o cartão de entrada é uma imagem impressa em preto e branco
{ "status": "OK", "message": { "blur": { "isBlur": "no", "score": 1 }, "ps": { "isPs": "no", "score": 8 }, "print": { "isPrint": "yes", "score": 100 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para o cartão de entrada é uma imagem de ataque de repetição
{ "status": "OK", "message": { "blur": { "isBlur": "no", "score": 1 }, "ps": { "isPs": "no", "score": 8 }, "print": { "isPrint": "no", "score": 0 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para o cartão de entrada é muito escuro ou muito claro
{ "status": "OK", "message": { "blur": { "isBlur": "no", "score": 1 }, "ps": { "isPs": "no", "score": 8 }, "print": { "isPrint": "no", "score": 0 }, "replayAttack": { "isReplayAttack": "no", "score": 10 } }}
Resposta para falha de reconhecimento
{ "status": "FAIL", "message": "check input image and retry"}
Resposta para parâmetros de solicitação inválidos
{ "status": "INVALID_REQUEST", "message": "check request params"}
Resposta para formato de imagem inválido
{ "status": "IMAGE_INVALID_FORMAT", "message": "image format not support"}
Resposta para imagem maior que 2M
{ "status": "IMAGE_INVALID_SIZE", "message": "image larger than 2M"}
Resposta para erro do servidor
{ "status": "INNER_ERROR", "message": "Inner error, please retry later"}
Solicitação HTTP
POST https://api.ekycpro.com/v1/id_card/antifake
Parâmetros da solicitação
parâmetro | descrição |
---|---|
img | string , imagem codificada em base64. Recomenda-se que a imagem tenha menos de 200KB, para que seja retornada em até 2 segundos, caso contrário, o tempo de retorno será maior. |
Formato da resposta
Os valores de pontuação abaixo são valores de referência. Recomenda-se ajustar as pontuações no uso real.
campos | descrição |
---|---|
isPs | yes rosto é PS, no rosto não é PS |
ps score | este é o nível de confiança do rosto PS, o intervalo é [0, 100]. O padrão é maior que 80 pontos é rosto PS |
isBlur | yes é desfocado, no não é desfocado |
blur score | este é o nível de confiança do cartão desfocado, o intervalo é [0, 100]. O padrão é maior que 30 pontos é cartão desfocado |
isPrint | yes é imagem impressa em preto e branco, no não é imagem impressa |
print score | este é o nível de confiança da imagem impressa, o intervalo é [0, 100]. O padrão é maior que 70 pontos é imagem impressa |
isReplayAttack | yes é uma imagem de ataque de repetição, no não é imagem de ataque de repetição |
replayAttack score | este é o nível de confiança da imagem de ataque de repetição, o intervalo é [0, 100]. O padrão é maior que 60 pontos é imagem de ataque de repetição |
Código de status
status | descrição |
---|---|
OK | charge , sucesso |
FAIL | charge , erro de reconhecimento de imagem, por favor verifique a imagem de entrada |
INVALID_REQUEST | free , parâmetros de solicitação inválidos |
IMAGE_INVALID_FORMAT | free , formato de imagem inválido, o formato da imagem deve ser um dos jpeg/jpg/png/bmp |
IMAGE_INVALID_SIZE | free , tamanho de imagem inválido, deve ser menor que 2M |
INNER_ERROR | free , erro do servidor |