5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

[MPEG-DASH] videoJSでアダプティブストリーミングを再生する

Last updated at Posted at 2020-05-24

はじめに

VideoJSでアダプティブストリーミングを行う方法を紹介します。(2020年5月現在)

VideoJSについては下記のページで紹介しています。
https://qiita.com/yun_bow/items/fe94d95c4eb4dc3a0803

動作環境
OS: Windows 10 Pro
Google Chrome: 81.0.4044.129
Mozilla Firefox: 75.0
Microsoft Edge: 81.0.416.64(Chromium版)
videoJS: 7.7.5
dashJS: 3.1.0
videoJS MPEG-DASH Source Handler: 2.11.0

ライブラリの読み込み

videoJS
https://github.com/videojs/video.js

dashJS
https://github.com/Dash-Industry-Forum/dash.js

videoJS MPEG-DASH Source Handler
https://github.com/videojs/videojs-contrib-dash

<script src="../lib/video.js"></script>
<script src="../lib/dash.all.debug.js"></script>
<script src="../lib/videojs-dash.js"></script>

DRMなし

デモはこちら

DRMなし
let video = videojs('video1', {
    width: 640, // 幅
    height: 360, // 高さ
    autoplay: false, // 自動再生
    loop: false, // ループ再生
    controls: true, // コントロール制御表示
    preload: 'auto', // 読み込み制御
});
video.src({
    type: 'application/dash+xml',
    src: '../../mpd/std/profile_live/Bullfinch.mpd'
});
ブラウザ名 動作可否
Google Chrome
Mozilla Firefox
Microsoft Edge

videoJSのメディアソースにtypeにmineType、srcにビデオリソースを指定します。

DRMあり

ClearKey

デモはこちら

ClearKey
video.src({
    type: 'application/dash+xml',
    src: '../../mpd/drm/clearkey/Bullfinch.mpd',
    keySystemOptions: [
        {
            name: 'org.w3.clearkey',
            options: {
                'clearkeys': {
                    'OCYfniLWkYVAQNXDwaqUeQ': 'jfUe14GofJhw1Sw0yde2eQ'
                }
            }
        }
    ]
});

ClearKeyでは、keySystemOptionsにおいて、nameにClearKeyのDRMシステム名、clearkeysにKeyID:Key を指定します。

ブラウザ名 動作可否
Google Chrome
Mozilla Firefox
Microsoft Edge

Widevine

デモはこちら

Widevine
video.src({
    type: 'application/dash+xml',
    src: '../../mpd/drm/widevine/Bullfinch.mpd',
    keySystemOptions: [
        {
            name: 'com.widevine.alpha',
            options: {
                serverURL: 'https://widevine-proxy.appspot.com/proxy'
            }
        }
    ]
});

Widevineでは、keySystemOptionsにおいて、nameにWidevineのDRMシステム名、serverURLにライセンスサーバーのURLを指定します。

ブラウザ名 動作可否
Google Chrome
Mozilla Firefox
Microsoft Edge

PlayReady

デモはこちら

PlayReady
video.src({
    type: 'application/dash+xml',
    src: '../../mpd/drm/playready/Bullfinch.mpd',
    keySystemOptions: [
        {
            name: 'com.microsoft.playready',
            options: {
                serverURL: 'https://test.playready.microsoft.com/service/rightsmanager.asmx?cfg=(kid:header,contentkey:jfUe14GofJhw1Sw0yde2eQ==)'
            }
        }
    ]
});

PlayReadyでは、keySystemOptionsにおいて、nameにPlayReadyのDRMシステム名、serverURLにライセンスサーバーのURLを指定します。

ブラウザ名 動作可否
Google Chrome ×
Mozilla Firefox ×
Microsoft Edge

マルチDRM(Widevine+PlayReady)

デモはこちら

マルチDRM
video.src({
    type: 'application/dash+xml',
    src: '../../mpd/drm/multi/Bullfinch.mpd',
    keySystemOptions: [
        {
            name: 'com.widevine.alpha',
            options: {
                serverURL: 'https://widevine-proxy.appspot.com/proxy'
            }
        },
        {
            name: 'com.microsoft.playready',
            options: {
                serverURL: 'https://test.playready.microsoft.com/service/rightsmanager.asmx?cfg=(kid:header,contentkey:O9ovQDRMfe9hQie5wPA+Jg==)'
            }
        }
    ]
});

マルチDRMでは、keySystemOptionsにDRMシステム名を複数指定します。ブラウザ側が対応しているDRMで再生を行います。

ブラウザ名 動作可否
Google Chrome
Mozilla Firefox
Microsoft Edge

おわりに

今回、videoJSによるアダプティブストリーミングの再生について纏めました。
メディアファイルの作成方法は別の投稿で紹介していますので
是非ご覧ください。ありがとうございました。

関連リンク

参考リンク

以上です。

5
4
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?