디지털 권한 관리

ExoPlayer는 Android의 MediaDrm API를 사용하여 DRM으로 보호되는 재생을 지원합니다. 지원되는 다양한 DRM 스키마에 필요한 최소 Android 버전과 이러한 스키마가 지원되는 스트리밍 형식이 다음 표에 설명되어 있습니다.

DRM 스키마 Android 버전 번호 Android API 레벨 지원되는 형식
Widevine 'cenc' 4.4 19 DASH, HLS (FMP4만 해당)
Widevine 'cbcs' 7.1 25 DASH, HLS (FMP4만 해당)
ClearKey 'cenc' 5.0 21 DASH
PlayReady SL2000 'cenc' Android TV Android TV DASH, SmoothStreaming, HLS (FMP4만 해당)

ExoPlayer로 DRM으로 보호된 콘텐츠를 재생하려면 미디어 항목을 빌드할 때 DRM 시스템의 UUID와 라이선스 서버 URI를 지정해야 합니다. 그런 다음 플레이어는 이러한 속성을 사용하여 대부분의 사용 사례에 적합한 DrmSessionManager의 기본 구현(DefaultDrmSessionManager)을 빌드합니다. 일부 사용 사례에서는 다음 섹션에 설명된 대로 추가 DRM 속성이 필요할 수 있습니다.

키 순환

순환 키로 스트림을 재생하려면 미디어 항목을 빌드할 때 trueMediaItem.DrmConfiguration.Builder.setMultiSession에 전달합니다.

여러 가지 주요 콘텐츠

다중 키 콘텐츠는 여러 스트림으로 구성되며 일부 스트림이 다른 스트림과 다른 키를 사용합니다. 다중 키 콘텐츠는 라이선스 서버가 구성된 방식에 따라 두 가지 방법 중 하나로 재생될 수 있습니다.

사례 1: 라이선스 서버가 콘텐츠의 모든 키로 응답

이 경우 라이선스 서버는 하나의 키에 관한 요청을 수신하면 콘텐츠의 모든 키로 응답하도록 구성됩니다. 이 사례는 특별한 구성 없이 ExoPlayer에서 처리됩니다. 스트림 (예: SD 및 HD 동영상) 간 적응은 다른 키를 사용하더라도 원활하게 이루어집니다.

가능하면 라이선스 서버가 이러한 방식으로 작동하도록 구성하는 것이 좋습니다. 이는 멀티키 콘텐츠의 재생을 지원하는 가장 효율적이고 강력한 방법입니다. 클라이언트가 서로 다른 스트림에 액세스하기 위해 여러 라이선스를 요청할 필요가 없기 때문입니다.

사례 2: 라이선스 서버가 요청된 키로만 응답함

이 경우 라이선스 서버는 요청에 지정된 키로만 응답하도록 구성됩니다. 미디어 항목을 빌드할 때 trueMediaItem.DrmConfiguration.Builder.setMultiSession에 전달하여 이 라이선스 서버 구성으로 다중 키 콘텐츠를 재생할 수 있습니다.

이와 같이 작동하도록 라이선스 서버를 구성하는 것은 권장하지 않습니다. 다중 키 콘텐츠를 재생하려면 추가 라이선스 요청이 필요합니다. 이 방법은 위에서 설명한 대안보다 덜 효율적이고 강력합니다.

오프라인 키

미디어 항목을 빌드할 때 키 세트 ID를 MediaItem.DrmConfiguration.Builder.setKeySetId에 전달하여 오프라인 키 세트를 로드할 수 있습니다. 이렇게 하면 지정된 ID로 설정된 오프라인 키에 저장된 키를 사용하여 재생할 수 있습니다.

선명한 콘텐츠를 위한 DRM 세션

자리표시자 DrmSessions를 사용하면 ExoPlayer가 암호화된 콘텐츠를 재생할 때 사용하는 것과 동일한 콘텐츠에 명확한 콘텐츠에 디코더를 사용할 수 있습니다. 미디어에 명확한 섹션과 암호화된 섹션이 모두 포함되어 있는 경우 자리표시자 DrmSessions를 사용하여 명확한 섹션과 암호화된 섹션 간 전환이 발생할 때 디코더가 다시 생성되지 않도록 할 수 있습니다. 미디어 항목을 빌드할 때 trueMediaItem.DrmConfiguration.Builder.forceSessionsForAudioAndVideoTracks에 전달하여 오디오 및 동영상 트랙에 자리표시자 DrmSessions를 사용할 수 있습니다.

맞춤 DrmSessionManager 사용

앱이 재생에 사용되는 DrmSessionManager를 맞춤설정하려는 경우 DrmSessionManagerProvider를 구현하여 플레이어를 빌드할 때 사용되는 MediaSource.Factory에 전달하면 됩니다. 제공자는 매번 새 관리자 인스턴스를 인스턴스화할지 여부를 선택할 수 있습니다. 항상 동일한 인스턴스를 사용하려면 다음 안내를 따르세요.

Kotlin

val customDrmSessionManager: DrmSessionManager = CustomDrmSessionManager()
// Pass a drm session manager provider to the media source factory.
val mediaSourceFactory =
  DefaultMediaSourceFactory(context).setDrmSessionManagerProvider { customDrmSessionManager }

Java

DrmSessionManager customDrmSessionManager = new CustomDrmSessionManager(/* ... */ );
// Pass a drm session manager provider to the media source factory.
MediaSource.Factory mediaSourceFactory =
    new DefaultMediaSourceFactory(context)
        .setDrmSessionManagerProvider(mediaItem -> customDrmSessionManager);

재생 성능 개선

Android 6.0 (API 수준 23)~Android 11 (API 수준 30)의 모든 Android 버전을 실행하는 기기에서 DRM으로 보호된 콘텐츠를 재생할 때 동영상 끊김이 발생하는 경우 비동기 버퍼 큐를 사용 설정해 보세요.