목차보기

One Click Multi DRM 재생 예제

VPE를 이용한 One Click Multi DRM 재생 예제입니다.


플레이어 (DRM 재생)

DRM 적용중 : No DRM
DRM을 지원하지 않는 장치입니다.



Backend JSON 예제 (optons.playlist[])

  • 해당 코드는 Backend API를 호출하여 JSON으로 받아온 playlist code입니다.
  • 아래 코드는 https://vpe.sgrsoft.com/api/drmTest 에서 확인 할 수 있습니다.
  • 아래 코드는 만료된 코드로 사용할 수 없습니다. 예제 API를 통신하여 예제 JSON을 확인하세요.
let playlist = [
  {
    "drm": {
      "com.widevine.alpha": {
        "src": "https://8kmgeiox5271.edge.naverncp.com/dash/~Mm2B8LV1K~dMoZUnpjc4g__/endpoint/sample/221027_NAVER_Cloud_intro_Long_ver_AVC_FHD_2Pass_30fps.mp4/manifest.mpd",
        "licenseUri": "https://multi-drm.apigw.ntruss.com/api/v1/license",
        "licenseRequestHeader": {
          "x-ncp-region_code": "KR",
          "x-ncp-iam-access-key": "ncp_iam_BPASKRX9k5Z9dX3VryI4",
          "x-ncp-apigw-timestamp": 1731552448128,
          "x-ncp-apigw-signature-v2": "kp3GlWpZEX26O9qfY1fb1UL8kX6DUmLLkrRaEMQBCls=",
          "x-drm-token": "eyJzaXRlSWQiOiJkcm0tMjAyNDA4MjYxMzE1MjgtVmpWeXIiLCJjb250ZW50SWQiOiJ2cGUtc2FtcGxlLXZvZC1kcm0iLCJkcm1UeXBlIjoiV0lERVZJTkUiLCJyZXNwb25zZUZvcm1hdCI6Im9yaWdpbmFsIiwidXNlcklkIjoidGVzdC11c2VyIn0="
        }
      },
      "com.microsoft.playready": {
        "src": "https://8kmgeiox5271.edge.naverncp.com/dash/~Mm2B8LV1K~dMoZUnpjc4g__/endpoint/sample/221027_NAVER_Cloud_intro_Long_ver_AVC_FHD_2Pass_30fps.mp4/manifest.mpd",
        "licenseUri": "https://multi-drm.apigw.ntruss.com/api/v1/license",
        "licenseRequestHeader": {
          "x-ncp-region_code": "KR",
          "x-ncp-iam-access-key": "ncp_iam_BPASKRX9k5Z9dX3VryI4",
          "x-ncp-apigw-timestamp": 1731552448128,
          "x-ncp-apigw-signature-v2": "kp3GlWpZEX26O9qfY1fb1UL8kX6DUmLLkrRaEMQBCls=",
          "x-drm-token": "eyJzaXRlSWQiOiJkcm0tMjAyNDA4MjYxMzE1MjgtVmpWeXIiLCJjb250ZW50SWQiOiJ2cGUtc2FtcGxlLXZvZC1kcm0iLCJkcm1UeXBlIjoiUExBWVJFQURZIiwicmVzcG9uc2VGb3JtYXQiOiJvcmlnaW5hbCIsInVzZXJJZCI6InRlc3QtdXNlciJ9"
        }
      },
      "com.apple.fps": {
        "src": "https://8kmgeiox5271.edge.naverncp.com/hls/~Mm2B8LV1K~dMoZUnpjc4g__/endpoint/sample/221027_NAVER_Cloud_intro_Long_ver_AVC_FHD_2Pass_30fps.mp4/index.m3u8",
        "certificateUri": "https://multi-drm.apigw.ntruss.com/api/v1/license/fairPlay",
        "certificateRequestHeader": {
          "x-ncp-region_code": "KR",
          "x-ncp-iam-access-key": "ncp_iam_BPASKRX9k5Z9dX3VryI4",
          "x-ncp-apigw-timestamp": 1731552448128,
          "x-ncp-apigw-signature-v2": "XEQvws0/feUiepEkCD7/WyakOjw2Jcmcmtia02YVPhE=",
          "x-drm-token": "eyJzaXRlSWQiOiJkcm0tMjAyNDA4MjYxMzE1MjgtVmpWeXIiLCJjb250ZW50SWQiOiJ2cGUtc2FtcGxlLXZvZC1kcm0iLCJkcm1UeXBlIjoiRkFJUlBMQVkiLCJyZXNwb25zZUZvcm1hdCI6Im9yaWdpbmFsIiwidXNlcklkIjoidGVzdC11c2VyIn0=",
          "accept": "application/json"
        },
        "licenseUri": "https://multi-drm.apigw.ntruss.com/api/v1/license",
        "licenseRequestHeader": {
          "x-ncp-region_code": "KR",
          "x-ncp-iam-access-key": "ncp_iam_BPASKRX9k5Z9dX3VryI4",
          "x-ncp-apigw-timestamp": 1731552448128,
          "x-ncp-apigw-signature-v2": "kp3GlWpZEX26O9qfY1fb1UL8kX6DUmLLkrRaEMQBCls=",
          "x-drm-token": "eyJzaXRlSWQiOiJkcm0tMjAyNDA4MjYxMzE1MjgtVmpWeXIiLCJjb250ZW50SWQiOiJ2cGUtc2FtcGxlLXZvZC1kcm0iLCJkcm1UeXBlIjoiRkFJUlBMQVkiLCJyZXNwb25zZUZvcm1hdCI6Im9yaWdpbmFsIiwidXNlcklkIjoidGVzdC11c2VyIn0="
        }
      }
    },
    "poster": "https://2ardrvaj2252.edge.naverncp.com/endpoint/sample/221027_NAVER_Cloud_intro_Long_ver_01.jpg",
    "description": {
      "title": "네이버클라우드 테스트 영상",
      "created_at": "2024.07.13",
      "profile_name": "네이버클라우드",
      "profile_image": "https://player.vpe.naverncp.com/images/d127c8db642716d84b3201f1d152e52a.png"
    }
  }
]

CDN 방식 코드


Vue3 (Nuxt.js + Tailwindcss)


React (Next.js + Tailwindcss)

ⓒ SGRSOFT. All Rights Reserved.