このトピックでは、ライブフィードを送信するための署名付きアップストリーミング URL と、視聴者がストリームを視聴するためのストリーミング URL を生成する方法について説明します。このプロセスは、安全で信頼性の高いライブストリーム配信を確保するために不可欠です。
開始する前に
ライブストリーミング URL を生成する前に、アップストリーミングドメインとストリーミングドメインを追加します。
各ドメインに対して複数のアップストリーミング URL とストリーミング URL を生成して、複数のライブイベントを同時にホストできます。アップストリーミングドメインの同時ストリーム数は制限されています。デフォルトでは、中国 (北京) 、中国 (上海) 、および中国 (深圳) リージョンのライブセンターは最大 300 の同時ストリームをサポートし、他のライブセンターは最大 50 をサポートします。詳細については、「制限」をご参照ください。
デフォルトでは、URL 署名はすべてのアップストリーミングドメインとストリーミングドメインで有効になっています。構成の詳細については、「URL 署名」をご参照ください。アップストリーミングと再生を有効にするには、URL にアクセストークンを追加する必要があります。
URL 構造
ApsaraVideo Live では、標準のライブストリーミング URL は、アップストリーミングまたはストリーミングドメイン、AppName、StreamName、および {access_token} で構成されます。
次の表に、これらのパラメーターを示します。
パラメーター | 説明 |
インジェスト/ストリーミング ドメイン | アップストリーミング URL はアップストリーミングドメインから生成し、ストリーミング URL はストリーミングドメインから生成します。 |
AppName | さまざまなアプリケーションやビジネスシナリオを区別するための、アプリケーションのカスタム名。 |
StreamName | ストリームの一意のカスタム名。 |
アクセストークン | MD5 アルゴリズムを使用して生成された、ライブストリームを保護するための暗号化された文字列。この文字列の生成方法の詳細については、「署名付きアップストリーミング URL とストリーミング URL」をご参照ください。 |
アップストリーミング URL の例
サポートされているプロトコル | 例 | 説明 |
RTMP |
| アップストリーミングの標準プロトコル。 |
ARTC |
| リアルタイムストリーミング (RTS) のアップストリーミング URL。 |
SRT |
| SRT プロトコルはデフォルトで無効になっています。このプロトコルを使用するには、アップストリーミングドメインで有効にします。詳細については、「SRT 経由のアップストリーミングの設定」をご参照ください。 |
ストリーミング URL の例
URL タイプ | 説明 | サポートされているプロトコル | 例 |
標準ストリーミング URL | アップストリーミングに SRT プロトコルを使用する場合、再生は RTMP、FLV、HLS、および ARTC でサポートされます。 | RTMP |
|
FLV |
| ||
HLS |
| ||
ARTC |
| ||
トランスコーディングされたストリーム URL (デフォルトのトランスコーディングまたはカスタムトランスコーディング) | StreamName に | RTMP |
|
FLV |
| ||
HLS |
| ||
ARTC |
| ||
トランスコーディングされたストリーム URL (マルチビットレートトランスコーディング) | マルチビットレートトランスコーディングストリームの場合は、StreamName に | HLS |
|
遅延ストリーム URL | 遅延ストリームの場合は、StreamName に | RTMP |
|
FLV |
| ||
HLS |
| ||
ARTC |
| ||
ライブ字幕ストリーム URL | StreamName に | RTMP |
|
FLV |
| ||
HLS |
|
URL の生成
コンソールから生成
ライブ URL ジェネレーターを使用して、コンソールでアップストリーミング URL とストリーミング URL を生成します。このツールは、暗号化された {access_token} を含む URL を生成します。
ライブ URL ジェネレーターは、ライブ字幕ストリーム URL の生成をサポートしていません。
コードを使用して生成
1. URI の構築
フォーマット {protocol}://{domain}/{AppName}/{streamName} を使用して URI を構築します。さまざまなプロトコルの例については、「アップストリーミング URL の例」および「ストリーミング URL の例」をご参照ください。
// 疑似コード
protocol = "rtmp"
domain = "example.aliyundoc.com"
appName = "liveApp"
streamName = "liveStream"
uri = protocol + "://" + domain + "/" + appName + "/" + streamName
// 結果: rtmp://example.aliyundoc.com/liveApp/liveStream2. 認証キーの取得
認証キーを使用してアクセストークンを生成します。キーは、URL 署名ページのコンソールから、または DescribeLiveDomainConfigs 操作を呼び出すことによって取得できます。
アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
3. 完全な URL のアセンブル
次のコードは、RTMP プロトコルを例として、{access_token} を生成し、完全なライブストリーミング URL をアセンブルする方法を示しています。
Java
import java.math.BigInteger;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class AuthDemo {
private static String md5Sum(String src) {
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
md5.update(StandardCharsets.UTF_8.encode(src));
return String.format("%032x", new BigInteger(1, md5.digest()));
}
private static String aAuth(String uri, String key, long exp) {
String pattern = "^(rtmp://)?([^/?]+)(/[^?]*)?(\\\\?.*)?$";
Pattern r = Pattern.compile(pattern);
Matcher m = r.matcher(uri);
String scheme = "", host = "", path = "", args = "";
if (m.find()) {
scheme = m.group(1) == null ? "rtmp://" : m.group(1);
host = m.group(2) == null ? "" : m.group(2);
path = m.group(3) == null ? "/" : m.group(3);
args = m.group(4) == null ? "" : m.group(4);
} else {
System.out.println("NO MATCH");
}
String rand = "0"; // デフォルトでは "0" ですが、他の値でもかまいません
String uid = "0"; // デフォルトでは "0" ですが、他の値でもかまいません
String sString = String.format("%s-%s-%s-%s-%s", path, exp, rand, uid, key);
String hashValue = md5Sum(sString);
String authKey = String.format("%s-%s-%s-%s", exp, rand, uid, hashValue);
if (args.isEmpty()) {
return String.format("%s%s%s%s?auth_key=%s", scheme, host, path, args, authKey);
} else {
return String.format("%s%s%s%s&auth_key=%s", scheme, host, path, args, authKey);
}
}
public static void main(String[] args) {
// 署名されるアップストリーミングまたはストリーミング URL。example.aliyundoc.com はアップストリーミングまたはストリーミングドメイン、liveApp は AppName、liveStream は StreamName です。
// アップストリーミング URL とストリーミング URL は同じ署名方法を使用します。
// AppName または StreamName は最大 256 文字で、数字、文字、ハイフン (-)、アンダースコア (_)、等号 (=) を含めることができます。
String uri = "rtmp://example.aliyundoc.com/liveApp/liveStream";
// 認証キー。アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
String key = "<秘密鍵を入力>";
// exp は秒単位の UNIX タイムスタンプです。URL の最終的な有効期限は、このタイムスタンプにドメインの URL 署名に設定された有効期間を加えたものです。
// たとえば、exp を現在の時刻 + 3600 秒に設定した場合、最終的な有効期限は現在の時刻 + 3600 秒 + 有効期間になります。exp を現在の時刻に設定した場合、最終的な有効期限は現在の時刻 + 有効期間になります。
long exp = System.currentTimeMillis() / 1000 + 1 * 3600;
String authUri = aAuth(uri, key, exp);
System.out.printf("URL : %s\nAuth: %s", uri, authUri);
}
}Python
import re
import time
import hashlib
import datetime
def md5sum(src):
m = hashlib.md5()
m.update(src)
return m.hexdigest()
def a_auth(uri, key, exp):
p = re.compile("^(rtmp://)?([^/?]+)(/[^?]*)?(\\?.*)?$")
if not p:
return None
m = p.match(uri)
scheme, host, path, args = m.groups()
if not scheme: scheme = "rtmp://"
if not path: path = "/"
if not args: args = ""
rand = "0" # デフォルトでは "0" ですが、他の値でもかまいません
uid = "0" # デフォルトでは "0" ですが、他の値でもかまいません
sstring = "%s-%s-%s-%s-%s" %(path, exp, rand, uid, key)
hashvalue = md5sum(sstring.encode('utf-8'))
auth_key = "%s-%s-%s-%s" %(exp, rand, uid, hashvalue)
if args:
return "%s%s%s%s&auth_key=%s" %(scheme, host, path, args, auth_key)
else:
return "%s%s%s%s?auth_key=%s" %(scheme, host, path, args, auth_key)
def main():
# 署名されるアップストリーミングまたはストリーミング URL。example.aliyundoc.com はアップストリーミングまたはストリーミングドメイン、liveApp は AppName、liveStream は StreamName です。
# アップストリーミング URL とストリーミング URL は同じ署名方法を使用します。
# AppName または StreamName は最大 256 文字で、数字、文字、ハイフン (-)、アンダースコア (_)、等号 (=) を含めることができます。
uri = "rtmp://example.aliyundoc.com/liveApp/liveStream"
# 認証キー。アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
key = "<秘密鍵を入力>"
# exp は秒単位の UNIX タイムスタンプです。URL の最終的な有効期限は、このタイムスタンプにドメインの URL 署名に設定された有効期間を加えたものです。
# たとえば、exp を現在の時刻 + 3600 秒に設定した場合、最終的な有効期限は現在の時刻 + 3600 秒 + 有効期間になります。exp を現在の時刻に設定した場合、最終的な有効期限は現在の時刻 + 有効期間になります。
exp = int(time.time()) + 1 * 3600
authuri = a_auth(uri, key, exp)
print("URL : %s\nAUTH: %s" %(uri, authuri))
if __name__ == "__main__":
main()Go
package main
import (
"crypto/md5"
"encoding/hex"
"fmt"
"regexp"
"time"
)
func md5sum(src string) string {
h := md5.New()
h.Write([]byte(src))
return hex.EncodeToString(h.Sum(nil))
}
func a_auth(uri, key string, exp int64) string {
p, err := regexp.Compile("^(rtmp://)?([^/?]+)(/[^?]*)?(\\?.*)?$")
if err != nil {
fmt.Println(err)
return ""
}
m := p.FindStringSubmatch(uri)
var scheme, host, path, args string
if len(m) == 5 {
scheme, host, path, args = m[1], m[2], m[3], m[4]
} else {
scheme, host, path, args = "rtmp://", "", "/", ""
}
rand := "0" // デフォルトでは "0" ですが、他の値でもかまいません
uid := "0" // デフォルトでは "0" ですが、他の値でもかまいません
sstring := fmt.Sprintf("%s-%d-%s-%s-%s", path, exp, rand, uid, key)
hashvalue := md5sum(sstring)
auth_key := fmt.Sprintf("%d-%s-%s-%s", exp, rand, uid, hashvalue)
if len(args) != 0 {
return fmt.Sprintf("%s%s%s%s&auth_key=%s", scheme, host, path, args, auth_key)
} else {
return fmt.Sprintf("%s%s%s%s?auth_key=%s", scheme, host, path, args, auth_key)
}
}
func main() {
// 署名されるアップストリーミングまたはストリーミング URL。example.aliyundoc.com はアップストリーミングまたはストリーミングドメイン、liveApp は AppName、liveStream は StreamName です。
// アップストリーミング URL とストリーミング URL は同じ署名方法を使用します。
// AppName または StreamName は最大 256 文字で、数字、文字、ハイフン (-)、アンダースコア (_)、等号 (=) を含めることができます。
uri := "rtmp://example.aliyundoc.com/liveApp/liveStream"
// 認証キー。アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
key := "<秘密鍵を入力>"
// exp は秒単位の UNIX タイムスタンプです。URL の最終的な有効期限は、このタイムスタンプにドメインの URL 署名に設定された有効期間を加えたものです。
// たとえば、exp を現在の時刻 + 3600 秒に設定した場合、最終的な有効期限は現在の時刻 + 3600 秒 + 有効期間になります。exp を現在の時刻に設定した場合、最終的な有効期限は現在の時刻 + 有効期間になります。
exp := time.Now().Unix() + 3600
authuri := a_auth(uri, key, exp)
fmt.Printf("URL : %s\nAUTH: %s", uri, authuri)
}PHP
<?php
function a_auth($uri, $key, $exp) {
preg_match("/^(rtmp:\/\/)?([^\/?]+)?(\/[^?]*)?(\\?.*)?$/", $uri, $matches);
$scheme = $matches[1];
$host = $matches[2];
$path = $matches[3];
$args = $matches[4];
if (empty($args)) {
$args ="";
}
if (empty($scheme)) {
$scheme ="rtmp://";
}
if (empty($path)) {
$path ="/";
}
$rand = "0";
// デフォルトでは "0" ですが、他の値でもかまいません
$uid = "0";
// デフォルトでは "0" ですが、他の値でもかまいません
$sstring = sprintf("%s-%u-%s-%s-%s", $path, $exp, $rand, $uid, $key);
$hashvalue = md5($sstring);
$auth_key = sprintf("%u-%s-%s-%s", $exp, $rand, $uid, $hashvalue);
if ($args) {
return sprintf("%s%s%s%s&auth_key=%s", $scheme, $host, $path, $args, $auth_key);
} else {
return sprintf("%s%s%s%s?auth_key=%s", $scheme, $host, $path, $args, $auth_key);
}
}
// 署名されるアップストリーミングまたはストリーミング URL。example.aliyundoc.com はアップストリーミングまたはストリーミングドメイン、liveApp は AppName、liveStream は StreamName です。
// アップストリーミング URL とストリーミング URL は同じ署名方法を使用します。
// AppName または StreamName は最大 256 文字で、数字、文字、ハイフン (-)、アンダースコア (_)、等号 (=) を含めることができます。
$uri = "rtmp://example.aliyundoc.com/liveApp/liveStream";
// 認証キー。アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
$key = "<秘密鍵を入力>";
// exp は秒単位の UNIX タイムスタンプです。URL の最終的な有効期限は、このタイムスタンプにドメインの URL 署名に設定された有効期間を加えたものです。
// たとえば、exp を現在の時刻 + 3600 秒に設定した場合、最終的な有効期限は現在の時刻 + 3600 秒 + 有効期間になります。exp を現在の時刻に設定した場合、最終的な有効期限は現在の時刻 + 有効期間になります。
$exp = time() + 3600;
$authuri = a_auth($uri, $key, $exp);
echo "URL :" . $uri;
echo PHP_EOL;
echo "AUTH:" . $authuri;
?>C#
using System;
using System.Text.RegularExpressions;
using System.Security.Cryptography;
using System.Text;
public class Test
{
public static void Main()
{
// 署名されるアップストリーミングまたはストリーミング URL。example.aliyundoc.com はアップストリーミングまたはストリーミングドメイン、liveApp は AppName、liveStream は StreamName です。
// アップストリーミング URL とストリーミング URL は同じ署名方法を使用します。
// AppName または StreamName は最大 256 文字で、数字、文字、ハイフン (-)、アンダースコア (_)、等号 (=) を含めることができます。
string uri= "rtmp://example.aliyundoc.com/liveApp/liveStream";
// 認証キー。アップストリーミング URL を生成するには、アップストリーミングドメインのキーを使用します。ストリーミング URL を生成するには、ストリーミングドメインのキーを使用します。
string key= "<秘密鍵を入力>";
DateTime dateStart = new DateTime(1970, 1, 1, 8, 0, 0);
// exp は秒単位の UNIX タイムスタンプです。URL の最終的な有効期限は、このタイムスタンプにドメインの URL 署名に設定された有効期間を加えたものです。
// たとえば、exp を現在の時刻 + 3600 秒に設定した場合、最終的な有効期限は現在の時刻 + 3600 秒 + 有効期間になります。exp を現在の時刻に設定した場合、最終的な有効期限は現在の時刻 + 有効期間になります。
string exp = Convert.ToInt64((DateTime.Now - dateStart).TotalSeconds+3600).ToString();
string authUri = aAuth(uri, key, exp);
Console.WriteLine (String.Format("URL :{0}",uri));
Console.WriteLine (String.Format("AUTH :{0}",authUri));
}
public static string aAuth(string uri, string key, string exp)
{
Regex regex = new Regex("^(rtmp://)?([^/?]+)(/[^?]*)?(\\\\?.*)?$");
Match m = regex.Match(uri);
string scheme = "rtmp://", host = "", path = "/", args = "";
if (m.Success)
{
scheme=m.Groups[1].Value;
host=m.Groups[2].Value;
path=m.Groups[3].Value;
args=m.Groups[4].Value;
}else{
Console.WriteLine ("NO MATCH");
}
string rand = "0"; // デフォルトでは "0" ですが、他の値でもかまいません
string uid = "0"; // デフォルトでは "0" ですが、他の値でもかまいません
string u = String.Format("{0}-{1}-{2}-{3}-{4}", path, exp, rand, uid, key);
string hashValue = Md5(u);
string authKey = String.Format("{0}-{1}-{2}-{3}", exp, rand, uid, hashValue);
if (args=="")
{
return String.Format("{0}{1}{2}{3}?auth_key={4}", scheme, host, path, args, authKey);
} else
{
return String.Format("{0}{1}{2}{3}&auth_key={4}", scheme, host, path, args, authKey);
}
}
public static string Md5(string value)
{
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
byte[] bytes = Encoding.ASCII.GetBytes(value);
byte[] encoded = md5.ComputeHash(bytes);
StringBuilder sb = new StringBuilder();
for(int i=0; i<encoded.Length; ++i)
{
sb.Append(encoded[i].ToString("x2"));
}
return sb.ToString();
}
}URL の使用と検証
URL を生成した後、エンドツーエンドのテストを実行して、正常に機能することを確認します。まず、ライブアップストリーミングにアップストリーミング URL を使用し、次に関連付けられたストリーミング URL をライブストリーム再生に使用します。
アップストリーミングまたは再生中に問題が発生した場合は、トラブルシューティングツールを使用して URL を検査し、アドレス、認証キー、およびその他の情報が有効であることを確認します。