门户中的“通过 HTML5 (IE/Chrome/Safari) 播放”选项映射到 Azure 媒体预设“H264 宽带 720p”。(有关系统提供的可用列表,请参阅http://msdn.microsoft.com/en-us/library/azure/dn619392.aspx)。此预设生成单比特率 mp4 文件、扩展名为 *.ism 的清单文件和 2 个带有元数据的 xml 文件。
您列出的网址是资产容器的网址,而不是您需要使用的 mp4 文件的网址。通过 osm player 播放资产有两种方式:指向 Azure 存储(SAS 定位器)和指向 Azure 媒体服务源服务器。下面的示例演示了如何为这两种情况构建 uri。在 sdk 扩展方法中简化了 Uri 结构。请参阅https://github.com/Azure/azure-sdk-for-media-services-extensions中的定位器扩展。
//Fetching existing job
IJob job = _mediaContext.Jobs.Where(c => c.Id == "nb:jid:UUID:29e033f5-402d-bc47-8f8d-56d83ff6915c").FirstOrDefault();
//Assume it has 1 output asset
IAsset asset = job.OutputMediaAssets[0];
//Access policy to publish asset for 5 days
const string days = "5days";
IAccessPolicy policy = _mediaContext.AccessPolicies.Where(c=>c.Name == days).FirstOrDefault();
//If not exists we creating access policy
if (policy == null)
{
policy =_mediaContext.AccessPolicies.Create(days, TimeSpan.FromDays(5), AccessPermissions.Read | AccessPermissions.List);
}
//Remove previously used locators
_mediaContext.Locators.ToList().ForEach(c=>c.Delete());
//Creating Sas Locator. Users directly access asset through Azure storage
ILocator sasLocator = _mediaContext.Locators.CreateLocator(LocatorType.Sas, asset, policy);
IAssetFile mp4File = asset.AssetFiles.Where(c => c.Name.Contains(".mp4")).FirstOrDefault();
string srcUri = sasLocator.BaseUri + "/" + mp4File.Name + sasLocator.ContentAccessComponent;
//Creating OnDemandOrigin Locator. Users access assets through origin server
ILocator ondemandOriginLocator = _mediaContext.Locators.CreateLocator(LocatorType.OnDemandOrigin, asset, policy);
IAssetFile ismFile = asset.AssetFiles.Where(c => c.Name.Contains(".ism")).FirstOrDefault();
string ondemandUri = ondemandOriginLocator.Path + ismFile.Name +"/Manifest";