视频转码基于转码模板发起,当视频点播提供的系统内置转码模板组无法满足您的转码需求时,您可以创建一个新的转码模板组,自定义模板中的编码格式、帧率、分辨率等参数。本文提供了Java SDK转码模板组相关的API调用示例,包含如何创建以及管理转码模板组。
接口调用说明
本文提供的接口调用示例均通过AccessKey初始化客户端实例。
接口的参数解释和返回字段的详细说明请访问阿里云OpenAPI门户,在各接口右侧的文档页签查看。
本文仅提供部分复杂接口的代码示例,其余接口的SDK代码示例,可以通过阿里云OpenAPI门户获取。访问阿里云OpenAPI门户,在接口的左侧参数配置页签,填写需要的参数信息并发起调用后,在右侧的SDK示例页签,选择SDK版本,选择目标语言,查看并下载示例代码。
本文均以V1.0版本的SDK为例进行接口调用,如需获取V2.0版本的SDK示例,请在通过阿里云OpenAPI门户获取SDK示例时,指定到对应的SDK版本。
初始化客户端
使用前请先初始化客户端,请参见初始化。
添加转码模板组
调用AddTranscodeTemplateGroup接口,生成添加转码模板组的SDK示例。
阿里云OpenAPI门户地址:AddTranscodeTemplateGroup。
调用示例如下:
import com.aliyuncs.auth.AlibabaCloudCredentials;
import com.aliyuncs.auth.EnvironmentVariableCredentialsProvider;
import com.aliyuncs.vod.model.v20170321.AddTranscodeTemplateGroupRequest;
import com.aliyuncs.vod.model.v20170321.AddTranscodeTemplateGroupResponse;
/**
* 读取AccessKey信息
*/
public static DefaultAcsClient initVodClient() throws ClientException {
// 点播服务接入地域
String regionId = "cn-shanghai";
// 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。
// 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
// 本示例通过从环境变量中读取AccessKey,来实现API访问的身份验证。运行代码示例前,请配置环境变量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
DefaultProfile profile = DefaultProfile.getProfile(regionId, System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"), System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET"));
DefaultAcsClient client = new DefaultAcsClient(profile);
return client;
}
/**
* 添加转码模板组配置
*/
public static AddTranscodeTemplateGroupResponse addTranscodeTemplateGroup(DefaultAcsClient client) throws Exception {
AddTranscodeTemplateGroupRequest request = new AddTranscodeTemplateGroupRequest();
//转码模板ID
request.setName("grouptest");
request.setTranscodeTemplateList(buildTranscodeTemplateList().toJSONString());
return client.getAcsResponse(request);
}
/**
* 构建需要添加的转码模板配置数据
*
* @return
*/
public static JSONArray buildTranscodeTemplateList() {
JSONObject transcodeTemplate = new JSONObject();
//模板名称
transcodeTemplate.put("TemplateName", "testtemplate");
//清晰度
transcodeTemplate.put("Definition", "LD");
//视频流转码配置
JSONObject video = new JSONObject();
video.put("Width", 640);
video.put("Bitrate", 400);
video.put("Fps", 25);
video.put("Remove", false);
video.put("Codec", "H.264");
video.put("Gop", "250");
transcodeTemplate.put("Video", video);
//音频流转码配置
JSONObject audio = new JSONObject();
audio.put("Codec", "AAC");
audio.put("Bitrate", "64");
audio.put("Channels", "2");
audio.put("Samplerate", "32000");
transcodeTemplate.put("Audio", audio);
//封装容器
JSONObject container = new JSONObject();
container.put("Format", "mp4");
transcodeTemplate.put("Container", container);
//条件转码配置
JSONObject transconfig = new JSONObject();
transconfig.put("IsCheckReso", false);
transconfig.put("IsCheckResoFail", false);
transconfig.put("IsCheckVideoBitrate", false);
transconfig.put("IsCheckVideoBitrateFail", false);
transconfig.put("IsCheckAudioBitrate", false);
transconfig.put("IsCheckAudioBitrateFail", false);
transcodeTemplate.put("TransConfig", transconfig);
//加密配置(只支持m3u8)
//JSONObject encryptSetting = new JSONObject();
//encryptSetting.put("EncryptType", "Private");
//transcodeTemplate.put("EncryptSetting", encryptSetting);
//水印ID(多水印关联)
JSONArray watermarkIdList = new JSONArray();
watermarkIdList.add("263261bdc1ff65782f8995c6dd22****");
//USER_DEFAULT_WATERMARK 代表默认水印ID
watermarkIdList.add("USER_DEFAULT_WATERMARK");
transcodeTemplate.put("WatermarkIds", watermarkIdList);
JSONArray transcodeTemplateList = new JSONArray();
transcodeTemplateList.add(transcodeTemplate);
return transcodeTemplateList;
}
/**
* 以下为调用示例
*/
public static void main(String[] args) throws ClientException {
DefaultAcsClient client = initVodClient();
AddTranscodeTemplateGroupResponse response = new AddTranscodeTemplateGroupResponse();
try {
response = addTranscodeTemplateGroup(client);
System.out.println("TranscodeTemplateGroupId = " + response.getTranscodeTemplateGroupId());
} catch (Exception e) {
System.out.println("ErrorMessage = " + e.getLocalizedMessage());
}
System.out.println("RequestId = " + response.getRequestId());
}
修改转码模板组
调用UpdateTranscodeTemplateGroup接口,生成修改转码模板组的SDK示例。
阿里云OpenAPI门户地址:UpdateTranscodeTemplateGroup。
调用示例如下:
import com.aliyuncs.auth.AlibabaCloudCredentials;
import com.aliyuncs.auth.EnvironmentVariableCredentialsProvider;
import com.aliyuncs.vod.model.v20170321.UpdateTranscodeTemplateGroupRequest;
import com.aliyuncs.vod.model.v20170321.UpdateTranscodeTemplateGroupResponse;
/**
* 读取AccessKey信息
*/
public static DefaultAcsClient initVodClient() throws ClientException {
// 点播服务接入地域
String regionId = "cn-shanghai";
// 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。
// 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
// 本示例通过从环境变量中读取AccessKey,来实现API访问的身份验证。运行代码示例前,请配置环境变量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
DefaultProfile profile = DefaultProfile.getProfile(regionId, System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"), System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET"));
DefaultAcsClient client = new DefaultAcsClient(profile);
return client;
}
/**
* 修改转码模板组配置
*/
public static UpdateTranscodeTemplateGroupResponse updateTranscodeTemplateGroup(DefaultAcsClient client) throws Exception {
UpdateTranscodeTemplateGroupRequest request = new UpdateTranscodeTemplateGroupRequest();
request.setName("grouptest1");
//转码模板组ID
request.setTranscodeTemplateGroupId("4c71a339fecec0152b4fa6f452****");
request.setTranscodeTemplateList(buildTranscodeTemplateList().toJSONString());
return client.getAcsResponse(request);
}
/**
* 构建需要修改的转码模板配置数据
*
* @return
*/
public static JSONArray buildTranscodeTemplateList() {
JSONObject transcodeTemplate = new JSONObject();
//转码模板ID
transcodeTemplate.put("TranscodeTemplateId", "85c2b18ac08fda33e8f6d9c56****");
//模板名称
transcodeTemplate.put("TemplateName", "testtemplate");
//视频流转码配置
JSONObject video = new JSONObject();
video.put("Width", 960);
video.put("Bitrate", 900);
video.put("Fps", 25);
video.put("Remove", false);
video.put("Codec", "H.264");
video.put("Gop", "250");
transcodeTemplate.put("Video", video);
//音频流转码配置
JSONObject audio = new JSONObject();
audio.put("Codec", "AAC");
audio.put("Bitrate", "96");
audio.put("Channels", "2");
audio.put("Samplerate", "32000");
transcodeTemplate.put("Audio", audio);
//封装容器
JSONObject container = new JSONObject();
container.put("Format", "mp4");
transcodeTemplate.put("Container", container);
//条件转码配置
JSONObject transconfig = new JSONObject();
transconfig.put("IsCheckReso", false);
transconfig.put("IsCheckResoFail", false);
transconfig.put("IsCheckVideoBitrate", false);
transconfig.put("IsCheckVideoBitrateFail", false);
transconfig.put("IsCheckAudioBitrate", false);
transconfig.put("IsCheckAudioBitrateFail", false);
transcodeTemplate.put("TransConfig", transconfig);
//加密配置(只支持m3u8)
JSONObject encryptSetting = new JSONObject();
encryptSetting.put("EncryptType", "Private");
//水印ID(多水印关联)
JSONArray watermarkIdList = new JSONArray();
watermarkIdList.add("263261bdc1ff65782f95c6dd22****");
//USER_DEFAULT_WATERMARK 代表默认水印ID
watermarkIdList.add("USER_DEFAULT_WATERMARK");
transcodeTemplate.put("WatermarkIds", watermarkIdList);
JSONArray transcodeTemplateList = new JSONArray();
transcodeTemplateList.add(transcodeTemplate);
return transcodeTemplateList;
}
/**
* 以下为调用示例
*/
public static void main(String[] args) throws ClientException {
DefaultAcsClient client = initVodClient();
UpdateTranscodeTemplateGroupResponse response = new UpdateTranscodeTemplateGroupResponse();
try {
response = updateTranscodeTemplateGroup(client);
System.out.println("TranscodeTemplateGroupId = " + response.getTranscodeTemplateGroupId());
} catch (Exception e) {
System.out.println("ErrorMessage = " + e.getLocalizedMessage());
}
System.out.println("RequestId = " + response.getRequestId());
}
查询转码模板组
调用GetTranscodeTemplateGroup接口,生成查询单个转码模板组信息的SDK示例。
阿里云OpenAPI门户地址:GetTranscodeTemplateGroup。
调用ListTranscodeTemplateGroup接口,生成查询转码模板组列表信息的SDK示例。
阿里云OpenAPI门户地址:ListTranscodeTemplateGroup。
设置默认转码模板组
调用SetDefaultTranscodeTemplateGroup接口,生成设置默认转码模板组的SDK示例。
阿里云OpenAPI门户地址:SetDefaultTranscodeTemplateGroup。
删除转码模板组
调用DeleteTranscodeTemplateGroup接口,生成删除转码模板组的SDK示例。
阿里云OpenAPI门户地址:DeleteTranscodeTemplateGroup。