명함
    • PDF

    명함

    • PDF

    기사 요약

    Classic/VPC 환경에서 이용 가능합니다.

    특화 모델 엔진을 사용하여 명함의 입력 정보(key-value)를 인식하고 추출합니다.

    요청

    요청 형식을 설명합니다. 요청 형식은 다음과 같습니다.

    메서드URI
    POST/name-card

    요청 헤더

    CLOVA OCR API에서 공통으로 사용하는 헤더에 대한 정보는 CLOVA OCR 요청 헤더를 참조해 주십시오.

    요청 바디

    요청 바디에 대한 설명은 다음과 같습니다.

    Content-Type: application/json인 경우

    요청 헤더 Content-Typeapplication/json인 경우의 요청 바디에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    versionString-버전 정보
    • V2만 사용
    requestIdStringRequired임의의 API 호출 UUID
    timestampIntegerRequired임의의 API 호출 시각(Timestamp)
    imagesArrayRequiredimages 세부 정보

    Content-Type: multipart/form-data인 경우

    요청 헤더 Content-Typemultipart/form-data인 경우의 요청 바디에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    messageObjectRequired요청 데이터 정보
    message.versionStringRequired버전 정보
    • V2만 사용
    message.requestIdStringRequired임의의 API 호출 UUID
    message.timestampIntegerRequired임의의 API 호출 시각(Timestamp)
    message.imagesArrayRequiredimages 세부 정보
    fileFileRequiredOCR 인식 이미지 파일

    images

    images에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    formatStringRequired이미지 형식
    • jpg | jpeg | png | pdf | tif | tiff
      • 이미지: jpg, jpeg, png
      • 단일 페이지: pdf, tif, tiff
    • 이미지 형식 중 하나를 선택하여 입력
    nameStringRequired임의의 이미지 이름
    • 이미지 식별 및 응답 결과 확인 시 사용
    dataStringRequiredBase64 인코딩된 이미지 데이터
    • Content-Type: application/json일 때 입력 가능

    요청 예시

    요청 예시는 다음과 같습니다.

    Content-Type: application/json인 경우

    요청 헤더 Content-Typeapplication/json인 경우의 요청 예시는 다음과 같습니다.

    curl --location --request POST 'https://cbgrx5natw.apigw.ntruss.com/custom/v1/{DomainId}/{InvokeKey}/document/name-card' \
    --header 'Content-Type: application/json' \
    --header 'X-OCR-SECRET: {앱 등록 시 발급받은 Secret Key}' \
    --data '{
        "version": "V2",
        "requestId": "1234",
        "timestamp": 0,
        "images": [
            { 
                "format": "jpg", 
                "name": "namecard_test2",
                "data": "{Base64 인코딩된 이미지 데이터}"
            }
        ]
    }'
    

    Content-Type: multipart/form-data인 경우

    요청 헤더 Content-Typemultipart/form-data인 경우의 요청 예시는 다음과 같습니다.

    curl --location --request POST 'https://cbgrx5natw.apigw.ntruss.com/custom/v1/{DomainId}/{InvokeKey}/document/name-card' \
    --header 'X-OCR-SECRET: {앱 등록 시 발급받은 Secret Key}' \
    --header 'Content-Type: multipart/form-data' \
    --form 'message="{\"version\": \"V2\", \"requestId\": \"1234\", \"timestamp\": 1724832750462, \"images\": [{\"format\": \"jpg\", \"name\": \"namecard_test\"}]}"' \
    --form 'file={file}.jpg"'
    

    응답

    응답 형식을 설명합니다.

    응답 바디

    응답 바디에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    versionString-버전 정보
    • V2만 사용
    requestIdString-API 호출 UUID
    timestampInteger-API 호출 시각(Timestamp)
    imagesArray-images 세부 정보

    images

    images에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    uidString-명함 이미지 UID
    • APi 유효성 검사 시 사용
    nameString-명함 이미지 이름
    • 이미지 식별 및 응답 결과 확인 시 사용
    inferResultString-명함 이미지 인식 결과
    • SUCCESS | FAILURE | ERROR
      • SUCCESS: 인식 성공
      • FAILURE: 인식 실패
      • ERROR: 인식 처리 예외
    messageString-결과 메시지
    validationResultObject-유효성 검사 결과 정보
    validationResult.resultString-유효성 검사 결과 코드
    • NO_REQUESTED | UNCHECKED | ERROR | VALID | INVALID
      • NO_REQUESTED: 검증 작업 미요청(유효성 검사 실패)
      • UNCHECKED: 검증 여부 확인 불가
      • ERROR: 검증 시 에러 발생(유효성 검사 실패)
      • VALID: 검증 결과 유효(유효성 검사 성공)
      • INVALID: 검증 통과 실패
    validationResult.messageString-유효성 검사 결과 세부 메시지
    • 항상 응답되는 값은 아님
    convertedImageInfoObject-변환 이미지 정보
    • formatpdf 또는 tiff일 때
    • 좌표 값은 호출 이미지 파일을 기준으로 설정
    convertedImageInfo.widthInteger-변환 이미지 가로 길이
    convertedImageInfo.heightInteger-변환 이미지 세로 길이
    convertedImageInfo.pageIndexInteger-변환 이미지 페이지 인덱스
    nameCardObject-명함 세부 정보
    nameCard.metaObject-메타 정보
    nameCard.meta.estimatedLanguageString-OCR 추정 언어
    • ko | en | ja
      • ko:한국어
      • en: 영어
      • ja: 일본어
    nameCard.resultObject-명함 OCR 인식 결과

    result

    result에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    nameArray-이름 정보
    nameFuriganaArray-후리가나 이름 정보
    • 공통 객체 정보 참조
    • 후리가나 이름 정보(nameCard.meta.estimatedLanguage)가 일본어(ja)일 경우만 응답
    companyArray-회사 정보
    addressArray-주소 정보
    positionArray-직급 정보
    departmentArray-부서 정보
    mobileArray-휴대폰 정보
    telArray-전화 정보
    faxArray-팩스 정보
    emailArray-이메일 정보
    homepageArray-홈페이지 정보

    공통 객체 정보

    공통 객체에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    textString-인식된 텍스트
    keyTextString-인식된 텍스트의 키 값
    confidenceScoreFloat-인식된 텍스트 신뢰도
    • 0~1
    • 신뢰도 값이 클수록 텍스트의 정확도가 높음
    boundingPolyObject-Bounding Poly 정보
    boundingPolysArray-boundingPoly 세부 정보
    maskingPolysArray-maskingPoly 세부 정보

    boundingPolys

    boundingPolys에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    verticesArray-vertices 세부 정보

    maskingPolys

    maskingPolys에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    verticesArray-vertices 세부 정보

    vertices

    boundingPolyVertices에 대한 설명은 다음과 같습니다.

    필드타입필수 여부설명
    xFloat-X축 좌표 값
    yFloat-Y축 좌표 값

    응답 상태 코드

    CLOVA OCR API에서 공통으로 사용하는 응답 상태 코드에 대한 정보는 CLOVA OCR 공통 응답 상태 코드를 참조해 주십시오.

    응답 예시

    응답 예시는 다음과 같습니다.

    성공

    호출이 성공한 경우의 응답 예시는 다음과 같습니다.

    {
        "version": "V2",
        "requestId": "1234",
        "timestamp": 1725235494383,
        "images": [
            {
                "uid": "{uid}",
                "name": "namecard_test",
                "inferResult": "SUCCESS",
                "message": "SUCCESS",
                "validationResult": {
                    "result": "NO_REQUESTED"
                },
                "nameCard": {
                    "meta": {
                        "estimatedLanguage": "ko"
                    },
                    "result": {
                        "name": [
                            {
                                "text": "김**",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 92.0,
                                                "y": 103.0
                                            },
                                            {
                                                "x": 218.0,
                                                "y": 103.0
                                            },
                                            {
                                                "x": 218.0,
                                                "y": 141.0
                                            },
                                            {
                                                "x": 92.0,
                                                "y": 141.0
                                            }
                                        ]
                                    }
                                ],
                                "maskingPolys": []
                            }
                        ],
                        "company": [
                            {
                                "text": "** **대리점",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 90.0,
                                                "y": 255.0
                                            },
                                            {
                                                "x": 237.0,
                                                "y": 255.0
                                            },
                                            {
                                                "x": 237.0,
                                                "y": 284.0
                                            },
                                            {
                                                "x": 90.0,
                                                "y": 284.0
                                            }
                                        ]
                                    }
                                ],
                                "maskingPolys": []
                            }
                        ],
                        "address": [
                            {
                                "text": "서울특별시 ***",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 91.0,
                                                "y": 287.0
                                            },
                                            {
                                                "x": 376.0,
                                                "y": 287.0
                                            },
                                            {
                                                "x": 376.0,
                                                "y": 312.0
                                            },
                                            {
                                                "x": 91.0,
                                                "y": 312.0
                                            }
                                        ]
                                    }
                                ],
                                "maskingPolys": []
                            }
                        ],
                        "position": [
                            {
                                "text": "****",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 226.0,
                                                "y": 114.0
                                            },
                                            {
                                                "x": 300.0,
                                                "y": 114.0
                                            },
                                            {
                                                "x": 300.0,
                                                "y": 138.0
                                            },
                                            {
                                                "x": 226.0,
                                                "y": 138.0
                                            }
                                        ]
                                    }
                                ],
                                "maskingPolys": []
                            }
                        ],
                        "mobile": [
                            {
                                "text": "010********",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 88.0,
                                                "y": 145.0
                                            },
                                            {
                                                "x": 300.0,
                                                "y": 145.0
                                            },
                                            {
                                                "x": 300.0,
                                                "y": 175.0
                                            },
                                            {
                                                "x": 88.0,
                                                "y": 175.0
                                            }
                                        ]
                                    }
                                ]
                            }
                        ],
                        "tel": [
                            {
                                "text": "02-****-****",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 89.0,
                                                "y": 311.0
                                            },
                                            {
                                                "x": 264.0,
                                                "y": 311.0
                                            },
                                            {
                                                "x": 264.0,
                                                "y": 333.0
                                            },
                                            {
                                                "x": 89.0,
                                                "y": 333.0
                                            }
                                        ]
                                    }
                                ]
                            }
                        ],
                        "fax": [
                            {
                                "text": "02-****-****",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 89.0,
                                                "y": 334.0
                                            },
                                            {
                                                "x": 264.0,
                                                "y": 334.0
                                            },
                                            {
                                                "x": 264.0,
                                                "y": 358.0
                                            },
                                            {
                                                "x": 89.0,
                                                "y": 358.0
                                            }
                                        ]
                                    }
                                ]
                            }
                        ],
                        "email": [
                            {
                                "text": "****@****.net",
                                "keyText": "",
                                "confidenceScore": 0.0,
                                "boundingPolys": [
                                    {
                                        "vertices": [
                                            {
                                                "x": 137.0,
                                                "y": 359.0
                                            },
                                            {
                                                "x": 312.0,
                                                "y": 359.0
                                            },
                                            {
                                                "x": 312.0,
                                                "y": 382.0
                                            },
                                            {
                                                "x": 137.0,
                                                "y": 382.0
                                            }
                                        ]
                                    }
                                ],
                                "maskingPolys": []
                            }
                        ]
                    }
                }
            }
        ]
    }
    

    실패

    호출이 실패한 경우의 응답 예시는 다음과 같습니다.

    {
        "version": "V2",
        "requestId": "1234",
        "timestamp": 1725235840459,
        "images": [
            {
                "uid": "{uid}",
                "name": "namecard_test2",
                "inferResult": "ERROR",
                "message": "Read page:0 error.",
                "validationResult": {
                    "result": "NO_REQUESTED"
                }
            }
        ]
    }
    

    이 문서가 도움이 되었습니까?

    Changing your password will log you out immediately. Use the new password to log back in.
    First name must have atleast 2 characters. Numbers and special characters are not allowed.
    Last name must have atleast 1 characters. Numbers and special characters are not allowed.
    Enter a valid email
    Enter a valid password
    Your profile has been successfully updated.