다음을 통해 공유


Azure AI Video Indexer API를 사용하여 얼굴 편집

Azure AI Video Indexer를 사용하여 비디오 속의 얼굴을 감지하고 식별할 수 있습니다. 개인의 얼굴을 흐리게 처리(편집)하도록 비디오를 수정하려면 API를 사용하면 됩니다.

여러 사람의 얼굴이 나오는 몇 분 길이의 영상을 수동으로 편집하려면 몇 시간이 걸릴 수 있지만, Video Indexer API의 사전 설정을 사용하면 몇 번의 간단한 단계를 통해 얼굴을 편집할 수 있습니다.

이 문서에서는 API를 사용하여 얼굴을 편집하는 방법을 보여줍니다. Video Indexer API에는 클라우드에서 확장성 있는 얼굴 감지 및 편집(흐리게 처리)을 제공하는 얼굴 편집 사전 설정이 포함되어 있습니다. 이 문서에서는 API를 사용하여 얼굴을 편집하는 각 단계를 자세히 설명합니다.

다음 비디오에서는 Azure AI Video Indexer API를 사용하여 비디오를 편집하는 방법을 보여줍니다.

규정 준수, 프라이버시 및 보안

다시 강조하지만, Video Indexer를 사용하여 얻은 분석 또는 인사이트를 사용할 때 모든 관련 법률을 준수해야 합니다.

Face 서비스 액세스는 Microsoft 책임 있는 AI 원칙을 지원하기 위해 자격 및 사용 기준에 따라 제한됩니다. Face 서비스는 Microsoft 관리 고객 및 파트너만 사용할 수 있습니다. 얼굴 인식 접수 양식을 사용하여 액세스를 적용합니다. 자세한 내용은 얼굴 제한 액세스 페이지를 참조하세요.

얼굴 편집 용어 및 계층 구조

Video Indexer의 얼굴 편집은 비디오 표준 및 고급 분석 사전 설정에 제공되는 기존 Video Indexer 얼굴 감지 결과의 출력을 사용합니다.

비디오를 편집하려면 먼저 Video Indexer에 비디오를 업로드하고 표준 또는 고급 비디오 사전 설정을 사용하여 분석을 완료해야 합니다. Azure AI Video Indexer 웹 사이트 또는 API를 사용하여 이 작업을 수행할 수 있습니다. 그 후 얼굴 편집 API에서 videoId 값을 사용하여 이 비디오를 참조할 수 있습니다. Microsoft에서는 표시된 얼굴이 편집되는 새 비디오를 만듭니다. 비디오 분석과 얼굴 편집 둘 다 별도로 요금이 청구될 수 있는 작업입니다. 자세한 내용은 가격 책정 페이지를 참조하세요.

흐리게 처리 유형

얼굴 편집에서 다양한 흐리게 처리 유형을 선택할 수 있습니다. 유형을 선택하려면 요청 본문에서 blurringKind 매개 변수의 이름 또는 대표 번호를 사용합니다.

blurringKind 번호 blurringKind 이름 예시
0 MediumBlur Azure AI Video Indexer 중간 흐림 사진.
1 HighBlur Azure AI Video Indexer의 높은 흐림 효과 사진.
2 LowBlur Azure AI Video Indexer 낮은 흐림 효과의 사진입니다.
3 BoundingBox Azure AI Video Indexer 경계 상자의 사진입니다.
4 검정 Azure AI Video Indexer 블랙박스 종류의 사진입니다.

요청 본문에서 blurringKind 매개 변수를 사용하여 흐리게 처리 종류를 지정할 수 있습니다.

예를 들면 다음과 같습니다.

{
    "faces": {
        "blurringKind": "HighBlur"
    }
}

또는 앞의 표에 설명된 흐리게 처리 유형을 나타내는 숫자를 사용합니다.

{
    "faces": {
        "blurringKind": 1
    }
}

필터

필터를 적용하여 흐리게 표시할 얼굴 ID를 설정할 수 있습니다. JSON 파일 본문의 쉼표로 구분된 배열에서 얼굴 ID를 지정할 수 있습니다. scope 매개 변수를 사용하여 이러한 얼굴을 편집 대상에서 제외하거나 편집 대상에 포함할 수 있습니다. ID를 지정한 후에는 사용자가 나타내는 ID를 제외한 모든 얼굴을 편집할 수도 있고, 해당 ID 편집할 수도 있습니다. 다음 섹션의 예제를 참조하세요.

Exclude 범위

다음 예제에서는 얼굴 ID 1001 및 1016을 제외한 모든 얼굴을 편집하기 위해 Exclude 범위를 사용합니다.

{
    "faces": {
        "blurringKind": "HighBlur",
        "filter": {
            "ids": [1001, 1016],
            "scope": "Exclude"
        }
    }
}

Include 범위

다음 예제에서는 얼굴 ID 1001 및 1016만 편집하기 위해 Include 범위를 사용합니다.

{
    "faces": {
        "blurringKind": "HighBlur",
        "filter": {
            "ids": [1001, 1016],
            "scope": "Include"
        }
    }
}

모든 얼굴 편집

모든 얼굴을 편집하려면 다음과 같이 범위 필터를 제거합니다.

{
    "faces": {
        "blurringKind": "HighBlur",
    }
}

얼굴 ID를 검색하려면 인덱싱된 비디오로 이동하여 아티팩트 파일을 검색하면 됩니다. 아티팩트는 비디오에서 감지된 모든 얼굴이 들어 있는 faces.json 파일과 썸네일 .zip 파일을 포함하고 있습니다. 얼굴을 ID와 매칭하고 편집할 얼굴 ID를 결정할 수 있습니다.

편집 작업 만들기

편집 작업을 만들려면 다음 API 호출을 호출합니다.

POST https://api.videoindexer.ai/{location}/Accounts/{accountId}/Videos/{videoId}/redact[?name][&priority][&privacy][&externalId][&streamingPreset][&callbackUrl][&accessToken]

다음 값은 필수입니다.

속성 설명
Accountid {accountId} Video Indexer 계정의 ID입니다.
Location {location} Video Indexer 계정이 있는 Azure 지역입니다. 예: westus.
AccessToken {token} Azure Resource Manager REST API를 통해 생성된 계정 기여자 권한이 있는 토큰입니다.
Videoid {videoId} 편집할 원본 비디오의 비디오 ID입니다. List Video API를 사용하여 비디오 ID를 검색할 수 있습니다.
Name {name} 편집된 새 비디오의 이름입니다.

다음은 요청 예시입니다.

https://api.videoindexer.ai/westeurope/Accounts/{id}/Videos/{id}/redact?priority=Low&name=testredaction&privacy=Private&streamingPreset=Default 

토큰을 bearertoken:{token} 키 값 형식의 인증 헤더로 지정할 수도 있고, ?token={token}을 사용하여 쿼리 매개 변수로 제공할 수도 있습니다.

또한 적용할 편집 작업 옵션을 사용하여 JSON 형식의 요청 본문을 추가해야 합니다. 예를 들면 다음과 같습니다.

{
    "faces": {
        "blurringKind": "HighBlur"
    }
}

요청이 성공하면 HTTP 202 ACCEPTED 응답을 받게 됩니다.

작업 상태 모니터링

작업 만들기 요청의 응답에서는 작업에 대한 URL이 있는 HTTP 헤더 Location을 받게 됩니다. 동일한 토큰을 사용하여 이 URL에 대한 GET 요청을 만들면 편집 작업의 상태를 확인할 수 있습니다.

다음은 URL 예시입니다.

https://api.videoindexer.ai/westeurope/Accounts/<id>/Jobs/<id>

다음은 응답의 예입니다.

{
    "creationTime": "2023-05-11T11:22:57.6114155Z",
    "lastUpdateTime": "2023-05-11T11:23:01.7993563Z",
    "progress": 20,
    "jobType": "Redaction",
    "state": "Processing"
}

Location 헤더에서 편집 작업이 완료될 때 동일한 URL을 호출하면 편집된 비디오에 대한 스토리지 SAS(공유 액세스 서명) URL을 받게 됩니다. 예시:

https://api.videoindexer.ai/westeurope/Accounts/<id>/Videos/<id>/SourceFile/DownloadUrl 

이 URL은 Azure Storage 계정에 저장된 .mp4 파일로 리디렉션됩니다.

FAQ

질문 답변
한 번의 작업으로 비디오를 업로드하고 수정할 수 있나요? 아니요. 먼저 Video Indexer API를 사용하여 비디오를 업로드하고 분석해야 합니다. 그 후 편집 작업에서 인덱싱된 비디오를 참조해야 합니다.
Azure AI Video Indexer 웹 사이트를 사용하여 비디오를 편집할 수 있나요? 아니요. 현재는 API를 사용하여 비디오를 편집하는 방법만 있습니다.
편집된 비디오를 Video Indexer 웹 사이트에서 재생할 수 있나요? 예. 편집된 비디오는 다른 인덱싱된 비디오와 마찬가지로 Video Indexer 웹 사이트에 표시되지만 인사이트를 포함하고 있지는 않습니다.
편집된 비디오를 삭제하려면 어떻게 해야 하나요? Delete Video API를 사용하여 편집된 비디오의 Videoid 값을 입력하면 됩니다.
얼굴 편집을 사용하려면 얼굴 식별 게이팅을 전달해야 하나요? 미국 내 경찰서를 대표하지 않는 한, 전달할 필요가 없습니다. 게이팅되더라도 얼굴 감지가 계속 제공됩니다. 게이팅되면 얼굴 식별이 제공되지 않습니다. 하지만 얼굴 감지만 사용하여 비디오의 모든 얼굴을 편집할 수 있습니다.
얼굴을 편집하면 원래 비디오를 덮어쓰나요? 아니요. 얼굴 편집 작업은 새 비디오 출력 파일을 만듭니다.
모든 얼굴이 제대로 편집되는 것은 아닙니다. 무엇을 도와드릴까요? 편집은 분석 파이프라인의 초기 얼굴 감지 및 감지 출력에 의존합니다. 대부분 모든 얼굴이 감지되지만 얼굴을 감지할 수 없는 상황이 있습니다. 얼굴 각도, 얼굴이 있는 프레임 수, 소스 비디오의 품질과 같은 요소는 얼굴 편집 품질에 영향을 줍니다. 자세한 내용은 얼굴 인사이트를 참조하세요.
얼굴 이외의 개체를 편집할 수 있나요? 아니요. 현재는 얼굴 편집만 가능합니다. 다른 개체를 편집해야 하는 경우 Azure 사용자 의견 채널에 제품 피드백을 남겨주세요.
편집된 비디오를 다운로드할 수 있는 SAS URL의 유효 기간은 얼마인가요? SAS URL이 만료된 후 편집된 비디오를 다운로드하려면 초기 작업 상태 URL을 호출해야 합니다. 나중에 참조할 수 있도록 이러한 Jobstatus URL을 백 엔드의 데이터베이스에 유지하는 것이 가장 좋습니다.

오류 코드

다음 섹션에서는 얼굴 편집을 사용할 때 발생할 수 있는 오류에 대해 설명합니다.

응답: 404 찾을 수 없음

계정을 찾을 수 없거나 비디오를 찾을 수 없습니다.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID(전역적으로 고유한 식별자)를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

응답 본문

이름 필수 Type
ErrorType false ErrorType
Message false string

기본 JSON

{
    "ErrorType": "GENERAL",
    "Message": "string"
}

응답: 400 잘못된 요청

입력이 잘못되었습니다. 또는 원래 업로드가 실패하여 비디오를 편집할 수 없습니다. 비디오를 다시 업로드하세요.

입력이 잘못되었습니다. 또는 원래 업로드가 실패하여 비디오를 편집할 수 없습니다. 비디오를 다시 업로드하세요.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

응답 본문

이름 필수 Type
ErrorType false ErrorType
Message false string

기본 JSON

{
    "ErrorType": "GENERAL",
    "Message": "string"
}

응답: 409 충돌

비디오를 이미 인덱싱 중입니다.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

응답 본문

이름 필수 Type
ErrorType false ErrorType
Message false string

기본 JSON

{
    "ErrorType": "GENERAL",
    "Message": "string"
}

응답: 401 권한 없음

액세스 토큰이 계정에 액세스할 권한이 없습니다.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

응답 본문

이름 필수 Type
ErrorType false ErrorType
Message false string

기본 JSON

{
    "ErrorType": "USER_NOT_ALLOWED",
    "Message": "Access token is not authorized to access account 'SampleAccountId'."
}

응답: 500 내부 서버 오류.

서버에서 오류가 발생했습니다.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

응답 본문

이름 필수 Type
ErrorType false ErrorType
Message false string

기본 JSON

{
    "ErrorType": "GENERAL",
    "Message": "There was an error."
}

응답: 429 요청이 너무 많음

너무 많은 요청이 전송되었습니다. Retry-After 응답 헤더를 사용하여 다음 요청을 보낼 시기를 결정합니다.

응답 헤더

이름 필수 Type 설명
Retry-After false 정수 응답을 받은 후 지연 시간(초)을 나타내는 음수가 아닌 10진수 정수입니다.

응답: 504 게이트웨이 시간 초과

서버가 예상 시간 내에 게이트웨이에 응답하지 않았습니다.

응답 헤더

이름 필수 Type 설명
x-ms-request-id false string 서버는 계측을 위해 요청의 GUID를 할당합니다. 서버는 요청 처리와 관련된 모든 로그를 서버 요청 ID에 연결할 수 있는지 확인합니다. 지원 엔지니어가 이 요청에 연결된 로그를 찾을 수 있도록, 클라이언트는 지원 티켓에 이 요청 ID를 제공할 수 있습니다. 서버는 요청 ID가 각 작업에 대해 고유한지 확인합니다.

기본 JSON

{
    "ErrorType": "SERVER_TIMEOUT",
    "Message": "Server did not respond to gateway within expected time"
}