日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

使用阿里云播放器實現全屏秒播

基于阿里云播放器SDK的預加載能力和點播設置視頻封面等策略的搭配使用,可實現視頻毫秒級的起播速度,能有效解決短視頻場景中的視頻起播慢,切換視頻卡頓等問題,為用戶呈現無感起播和流暢絲滑的播放體驗。本文介紹如何使用阿里云播放器SDK實現全屏秒播。

方案原理

播放視頻時,在起播階段因加載視頻需要一定的時間,因此播放可能會出現一段黑屏的時間。一方面,可以通過開啟阿里云播放器的預加載功能以及通過預熱視頻資源來提升視頻的起播速度。另一方面,由于圖片的加載速度比視頻加載速度快的更多,此時如果設置了視頻封面圖,則起播階段視頻還未加載出來時,可以由封面圖占據播放頁面直到視頻加載出來開始播放,從而避免視頻黑屏的視覺效果;而通過將視頻的首幀截圖設置為視頻封面,使用戶感覺不到視頻封面的存在,以達到視頻秒開極快的視覺效果。

通過此方案,在WiFi環境下可以實現使用阿里云播放器播放視頻達到平均300毫秒左右的起播速度。

使用限制

  • 目前僅支持通過阿里云Android播放器SDK和iOS播放器SDK實現全屏秒播。

  • 目前僅支持MP4、MP3、FLV、HLS(單碼率視頻流)等單個媒體文件實現預加載功能。

  • 預加載僅支持使用UrlSource方式播放視頻,暫不支持VidAuth、VidSts方式播放視頻。

前提條件

步驟一:開啟阿里云播放器SDK的預加載功能

阿里云播放器SDK的預加載功能,通過提前將視頻數據加載到本地,來提升視頻的起播速度。

使用限制

  • 目前支持MP4、MP3、FLV、HLS(單碼率視頻流)等單個媒體文件的加載。

  • 僅支持UrlSource播放方式播放視頻的預加載,暫不支持VidAuth、VidSts方式播放視頻的預加載。

Android播放器配置

  1. 開啟本地緩存功能。

    /app/src/main/java/com/aliyun/alivcsolution/MutiApplication.java文件中,通過AliPlayerGlobalSettings.enableLocalCache開啟。

    public class MutiApplication extends Application {
    
        @Override
        protected void attachBaseContext(Context base) {
            super.attachBaseContext(base);
            MultiDex.install(this);
        }
    
        @Override
        public void onCreate() {
            super.onCreate();
            //開啟本地緩存,本地緩存文件路徑,為絕對路徑,下述示例為/tmp,下述示例中10240對應的參數在5.4.7.1及以后版本已廢棄,暫無作用
            AliPlayerGlobalSettings.enableLocalCache(true,10240,"/tmp");
    
          
        }
    
    }
  2. 創建預加載單例,并在初始化時設置預加載的回調函數。

    /AliyunListPlayer/src/main/java/com/aliyun/player/aliyunlistplayer/AliyunListPlayerActivity.java文件中創建。

    public class AliyunListPlayerActivity extends AppCompatActivity {
    
        private AliyunListPlayerView mListPlayerView;
        private NetWatchdog mNetWatchDog;
        private String mUserToken;
        private boolean mIsLoadMore = false;
        private int mLastVideoId = -1;
        private ImageView mBackImageView;
        
        //創建預加載單例
        private MediaLoader medialoader=MediaLoader.getInstance();
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_aliyun_list_player);
            mUserToken = getIntent().getStringExtra("list_player_user_token");
    
            initView();
            initSts(true);
            initListener();
    
    
            //設置加載狀態回調
            medialoader.setOnLoadStatusListener(new MediaLoader.OnLoadStatusListener() {
                @Override
                public void onError(String url, int code, String msg) {
                    //加載出錯
                }
    
                @Override
                public void onCompleted(String s) {
                    //加載完成
                }
    
                @Override
                public void onCanceled(String s) {
                    //加載取消
                }
            });
        }
        ...
  3. 在請求數據響應時,調用load函數實現預加載數據存儲到指定磁盤路徑中。

    private void getDatas(int id){
            GetVideoInfomation getVideoInfomation = new GetVideoInfomation();
            getVideoInfomation.getListPlayerVideoInfos(this, "1", mUserToken, id, new GetVideoInfomation.OnGetListPlayerVideoInfosListener() {
                private SparseArray<String> mSparseArray;
                @Override
                public void onGetSuccess(Request request, String result) {
                    //demo列表播放器實現中,僅根據video id請求視頻數據
                    //但是預加載只能通過url實現,不能通過video id預加載視頻數據
                    //這里只是做一個說明,在拿到url后,如何通過medialoader實現預加載
                    String url="";//假設這里拿到了視頻url
                    medialoader.load(url,10000);//預加載數據存儲到指定磁盤路徑中,加載時長為10000毫秒
    
                    Gson gson = new Gson();
                    AliyunVideoListBean aliyunVideoListBean = gson.fromJson(result, AliyunVideoListBean.class);
                    
                    ...

iOS播放器配置

  1. 在初始化時,開啟本地緩存功能并設置預加載的回調函數。

    - (AliPlayer *)aliPlayer{
        if (!_aliPlayer && UIApplicationStateActive == [[UIApplication sharedApplication] applicationState]) {
            _aliPlayer = [[AliPlayer alloc] init];
            _aliPlayer.scalingMode =  AVP_SCALINGMODE_SCALEASPECTFIT;
            _aliPlayer.rate = 1;
            _aliPlayer.delegate = self;
            _aliPlayer.playerView = self.playerView;
    
            //開啟本地緩存,本地緩存文件路徑沙盒路徑,maxBufferMemoryKB對應的10240對應的參數在5.4.7.1及以后版本已廢棄,暫無作用
            NSString *docDir = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) firstObject];
            [AliPlayerGlobalSettings enableLocalCache:YES maxBufferMemoryKB:10*1024 localCacheDir:[docDir stringByAppendingPathComponent:@"alivcCache"]];
            [AliPlayerGlobalSettings setCacheFileClearConfig:30*60*24 maxCapacityMB:20480 freeStorageMB:0];
            //設置url回調方法,這里避免預加載時的url和播放時的url由于參數的變化導致不一致造成預加載失效
            [AliPlayerGlobalSettings setCacheUrlHashCallback:hashCallback];
            
            //設置回調代理
            [[AliMediaLoader shareInstance] setAliMediaLoaderStatusDelegate:self];
    
        }
        return _aliPlayer;
    }
    
    //設置url回調方法
    NSString* hashCallback(NSString* url){
        NSString *md5Str = [NSString aliyun_MD5:url];
        return md5Str;
    }
    
    //預加載的回調方法
    #pragma mark -- AliMediaLoaderStatusDelegate
    /**
     @brief 錯誤回調
     @param url 加載url
     @param code 錯誤碼
     @param msg 錯誤描述
     */
    - (void)onError:(NSString *)url code:(int64_t)code msg:(NSString *)msg {
        
    }
    
    /**
     @brief 完成回調
     @param url 加載url
     */
    - (void)onCompleted:(NSString *)url {
        
    }
    
    /**
     @brief 取消回調
     @param url 加載url
     */
    - (void)onCanceled:(NSString *)url {
        
    }

  2. 設置數據源時,調用load函數實現預加載數據存儲到指定磁盤路徑。

    NSString *urlString = @"<url地址>";
    AVPUrlSource *urlSource = [[AVPUrlSource alloc] urlWithString:urlString];
    [_aliPlayer setUrlSource:urlSource];
    [[AliMediaLoader shareInstance] load:urlString duration:10000];//預加載數據存儲到指定磁盤路徑中,加載時長示例為10000毫秒

步驟二:設置視頻首幀截圖為視頻封面

通過將視頻首幀截圖設置為視頻封面,以達到視頻秒開極快的視覺效果。

說明

當使用阿里云播放器播放視頻時,在列表播放的場景下,您可以結合視頻封面設置如下播放邏輯來達到秒開的視覺效果并節省流量。

  • 當用戶快速滑動切換視頻時,僅僅只請求視頻封面圖。

  • 當用戶切換下一個視頻滑動到一半時,展示預先下載的視頻封面圖。

控制臺方式配置

  1. 創建截取視頻首幀的截圖模板。

    1. 登錄視頻點播控制臺

    2. 在左側導航欄選擇配置管理 > 媒體處理配置 > 截圖模板,進入到截圖模板頁面。

    3. 單擊添加截圖模板,配置截取視頻首幀截圖的模板參數。

      模板名稱請自定義設置,截圖方式選擇普通截圖起始時間點設置為00:00:00,截圖數量設置為1,其余參數請按需配置,有關截圖模板的參數解釋,詳情請參見截圖模板首幀截圖1.png

    4. 單擊保存,完成截圖模板的創建。

  2. 發起截取視頻首幀的截圖任務。

    說明
    • 通過控制臺方式發起截圖任務時,只能通過工作流的方式發起,因此,您需要先創建一個包含視頻首幀截圖任務的工作流(即在工作流中添加視頻截圖節點,并設置截圖模板為上一步創建的首幀截圖模板)。工作流的創建方法,請參見工作流管理

    • 建議您發起截圖任務之前,配置視頻點播的事件通知,通過設置視頻截圖完成的事件通知,以便在截圖任務完成后,能獲取到截圖任務的狀態及截取的圖片地址等信息。事件通知的配置方法,請參見回調設置

    • 場景一:上傳視頻時截圖

      1. 在視頻點播控制臺,從左側導航欄選擇媒資庫 > 音/視頻

      2. 單擊上傳音/視頻,單擊添加音/視頻

      3. 按需設置上傳方式、存儲地址并添加上傳的視頻后,選擇用工作流處理,并選擇預先創建的包含首幀截圖任務的工作流。

      4. 單擊開始上傳

    • 場景二:上傳視頻后截圖

      1. 在視頻點播控制臺,從左側導航欄選擇媒資庫 > 音/視頻

      2. 在音/視頻列表頁面,單擊目標視頻所在行的媒體處理

      3. 處理類型選擇用工作流處理工作流選擇預先創建的包含首幀截圖任務的工作流。

      4. 單擊確定

    • 獲取截圖結果

      • 如果您已經配置了視頻點播的視頻截圖完成的事件通知,您可以從回調事件中獲取到截圖任務的狀態及截取的圖片地址等信息。

      • 如果您未配置事件通知,您可以使用輪詢的方式調用ListSnapshots - 查詢截圖數據接口來查詢截圖任務的狀態及截取的圖片地址等信息。

  3. 修改視頻封面為視頻首幀截圖。

    說明

    通過控制臺方式修改視頻封面,只支持在視頻上傳完成后對視頻封面進行更新。您需要先將步驟2中截圖任務截取到的視頻首幀截圖保存到本地以便修改封面時上傳。

    1. 在視頻點播控制臺,從左側導航欄選擇媒資庫 > 音/視頻

    2. 在音/視頻列表頁面,單擊目標視頻所在行的管理

    3. 基礎信息頁簽,單擊編輯視頻信息

    4. 單擊上傳封面,選擇預先保存到本地的視頻首幀截圖,單擊打開

    5. 單擊保存,完成視頻封面設置。

      設置完成后,您可以在音/視頻列表頁面查看視頻封面是否更新成功。

OpenAPI方式配置

說明

本文以使用Java語言的阿里云 SDK方式調用視頻點播的OpenAPI為例進行舉例說明。

操作步驟

  1. 創建截取視頻首幀的截圖模板。

    調用AddVodTemplate - 添加截圖或動圖模板接口,創建截取視頻首幀的截圖模板。調用示例如下:

    import com.aliyuncs.DefaultAcsClient;
    import com.aliyuncs.exceptions.ClientException;
    import com.aliyuncs.profile.DefaultProfile;
    import com.aliyuncs.vod.model.v20170321.AddVodTemplateRequest;
    import com.aliyuncs.vod.model.v20170321.AddVodTemplateResponse;
    
    
    /**
     * 說明:
     * 1. 本Demo為創建首幀截圖模板示例,截圖輸出為 1 張圖片。
     * 2. 推薦使用視頻點播控制臺創建截圖模板,更加方便快捷。
     */
    public class AddSnapshotTemplate {
    
        // 阿里云賬號AccessKey擁有所有API的訪問權限,建議您使用RAM用戶進行API訪問或日常運維。
        // 強烈建議不要把AccessKey ID和AccessKey Secret保存到工程代碼里,否則可能導致AccessKey泄露,威脅您賬號下所有資源的安全。
        // 本示例通過從環境變量中讀取AccessKey,來實現API訪問的身份驗證。運行代碼示例前,請配置環境變量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
        public static String accessKeyId = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
        public static String accessKeySecret = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");
    
        public static void main(String[] args) {
    
            try{
                DefaultAcsClient vodClient = initVodClient(accessKeyId, accessKeySecret);
                AddVodTemplateResponse response = addSnapshotTemplate(vodClient);
                System.out.println("RequestId is:" + response.getRequestId());
                System.out.println("TemplateId is:" + response.getVodTemplateId());
            }catch (Exception e){
    
            }
        }
    
        public static AddVodTemplateResponse addSnapshotTemplate(DefaultAcsClient vodClient) throws ClientException {
            AddVodTemplateRequest request = new AddVodTemplateRequest();
            request.setName("首幀截圖模板");
            request.setTemplateType("Snapshot");
            request.setTemplateConfig("{\"SnapshotType\":\"NormalSnapshot\",\"SnapshotConfig\":{\"FrameType\":\"normal\",\"Count\":1,\"Interval\":1,\"SpecifiedOffsetTime\":0}}");
    
            return vodClient.getAcsResponse(request);
        }
    
        public static DefaultAcsClient initVodClient(String accessKeyId, String accessKeySecret) throws ClientException {
            // 點播服務接入區域
            String regionId = "cn-shanghai";  
            DefaultProfile profile = DefaultProfile.getProfile(regionId, accessKeyId, accessKeySecret);
            DefaultAcsClient client = new DefaultAcsClient(profile);
    
            return client;
        }
    }
    
  2. 發起截取視頻首幀的截圖任務。

    調用SubmitSnapshotJob - 提交媒體截圖作業接口,發起截圖任務。調用示例如下:

    import com.aliyuncs.DefaultAcsClient;
    import com.aliyuncs.exceptions.ClientException;
    import com.aliyuncs.profile.DefaultProfile;
    import com.aliyuncs.vod.model.v20170321.*;
    
    /**
     * 說明:
     * 1. 本Demo為創建首幀截圖模板后,提交首幀截圖任務。
     * 2. 對于新上傳的視頻,建議該步驟放在【音視頻分析完成】事件成功之后,對于存量且狀態正常的視頻,可自行設計。
     * 3. 截圖為異步任務,需要等到【視頻截圖完成】事件成功之后(推薦),可獲取截圖地址。
     * 4. 根據回調事件中的SnapshotRegular,可推測出截圖輸出地址。詳情請參見【視頻截圖完成】文檔中的截圖地址生成規則說明。
     * 5. 若您暫無回調服務,也可以通過ListSnapshots接口主動查詢,該接口默認只返回最新一次的截圖結果。詳情請參見ListSnapshots接口文檔。
     */
    public class SubmitSnapshotJob {
    
        // 阿里云賬號AccessKey擁有所有API的訪問權限,建議您使用RAM用戶進行API訪問或日常運維。
        // 強烈建議不要把AccessKey ID和AccessKey Secret保存到工程代碼里,否則可能導致AccessKey泄露,威脅您賬號下所有資源的安全。
        // 本示例通過從環境變量中讀取AccessKey,來實現API訪問的身份驗證。運行代碼示例前,請配置環境變量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
        public static String accessKeyId = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
        public static String accessKeySecret = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");
    
        public static void main(String[] args) {
    
            try{
                DefaultAcsClient vodClient = initVodClient(accessKeyId, accessKeySecret);
                SubmitSnapshotJobResponse response = submitSnapshotJob(vodClient);
                System.out.println("RequestId is:" + response.getRequestId());
                System.out.println("JobId is:" + response.getSnapshotJob().getJobId());
            }catch (Exception e){
    
            }
        }
    
        public static SubmitSnapshotJobResponse submitSnapshotJob(DefaultAcsClient vodClient) throws ClientException {
            SubmitSnapshotJobRequest request = new SubmitSnapshotJobRequest();
            request.setVideoId("a42b**********633b79f0102");
            request.setSnapshotTemplateId("1f27a7**********eba2756");
            //自定義透傳參數,回調時可用,非必須,用于區分封面首幀截圖
            request.setUserData("{\"Extend\":{\"SnapshotType\":\"FirstFrame\",\"VideoId\":\"a42bf540********33b79f0102\"}}");
            return vodClient.getAcsResponse(request);
        }
    
        public static DefaultAcsClient initVodClient(String accessKeyId, String accessKeySecret) throws ClientException {
            // 點播服務接入區域
            String regionId = "cn-shanghai";  
            DefaultProfile profile = DefaultProfile.getProfile(regionId, accessKeyId, accessKeySecret);
            DefaultAcsClient client = new DefaultAcsClient(profile);
    
            return client;
        }
    
        //ListSnapshots 查詢截圖
        public static ListSnapshotsResponse listSnapshots(DefaultAcsClient vodClient) throws ClientException {
            ListSnapshotsRequest request = new ListSnapshotsRequest();
            request.setVideoId("a42bf540b1b371ed804a6633b79****");
            request.setSnapshotType("NormalSnapshot");
    
            ListSnapshotsResponse response = vodClient.getAcsResponse(request);
            System.out.println("RequestId is:" + response.getRequestId());
            System.out.println("SnapshotUrl is:" + response.getMediaSnapshot().getSnapshots().get(0).getUrl());
            return vodClient.getAcsResponse(request);
        }
    
    }
    
  3. 修改視頻封面為視頻首幀截圖。

    此處以視頻上傳完成后,修改單個視頻封面的場景為例進行說明,其他場景的實現,請參見上傳視頻時設置封面視頻上傳后更新封面

    通過調用UpdateVideoInfo - 修改單個音視頻信息接口,傳入CoverURL參數指定視頻封面。調用示例如下:

    package com.alibaba.bltest.transcode;
    
    import com.aliyuncs.DefaultAcsClient;
    import com.aliyuncs.exceptions.ClientException;
    import com.aliyuncs.profile.DefaultProfile;
    import com.aliyuncs.vod.model.v20170321.UpdateVideoInfoRequest;
    import com.aliyuncs.vod.model.v20170321.UpdateVideoInfoResponse;
    
    /**
     * 說明:
     * 1. 本Demo為修改單個視頻封面,如需修改其他視頻參數,請參見UpdateVideoInfo的接口文檔。
     * 2. 對于修改封面的場景,請確保您使用的圖片地址是有效的。
     */
    public class UpdateVideoInfo {
    
        // 阿里云賬號AccessKey擁有所有API的訪問權限,建議您使用RAM用戶進行API訪問或日常運維。
        // 強烈建議不要把AccessKey ID和AccessKey Secret保存到工程代碼里,否則可能導致AccessKey泄露,威脅您賬號下所有資源的安全。
        // 本示例通過從環境變量中讀取AccessKey,來實現API訪問的身份驗證。運行代碼示例前,請配置環境變量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
        public static String accessKeyId = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
        public static String accessKeySecret = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");
    
        public static void main(String[] args) {
    
            try{
                DefaultAcsClient vodClient = initVodClient(accessKeyId, accessKeySecret);
                UpdateVideoInfoResponse response = updateVideoInfo(vodClient);
                System.out.println("RequestId is:" + response.getRequestId());
            }catch (Exception e){
    
            }
        }
    
        public static UpdateVideoInfoResponse updateVideoInfo(DefaultAcsClient vodClient) throws ClientException {
            UpdateVideoInfoRequest request = new UpdateVideoInfoRequest();
            request.setVideoId("a42b***********33b79f0102");
            //設置首幀封面時,CoverURL為首幀截圖任務成功后輸出的圖片地址
            request.setCoverURL("http://demo.aliyuncdn.com/a42bf5******40b1b37/snapshots/normal/41B7AF54-18672BB301D-1748-0984-309-112420****.jpg");
    
            return vodClient.getAcsResponse(request);
        }
    
        public static DefaultAcsClient initVodClient(String accessKeyId, String accessKeySecret) throws ClientException {
            // 點播服務接入區域
            String regionId = "cn-shanghai";  
            DefaultProfile profile = DefaultProfile.getProfile(regionId, accessKeyId, accessKeySecret);
            DefaultAcsClient client = new DefaultAcsClient(profile);
            return client;
        }
    }
    

完整實例

package com.alibaba.bltest.transcode;


import com.alibaba.fastjson.JSONObject;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.vod.model.v20170321.*;
import org.apache.commons.lang3.StringUtils;

/**
 * 說明:
 * 1. 本Demo為完整截圖+修改封面邏輯設計,部分代碼需要根據自己業務邏輯自行修改。
 * 2. 本Demo非直接可用,部分邏輯需要自行補充。
 * 3. 本Demo僅供實現參考,不代表唯一實現方式。
 */
public class SnapshotAndUpdateCover {

    // 阿里云賬號AccessKey擁有所有API的訪問權限,建議您使用RAM用戶進行API訪問或日常運維。
    // 強烈建議不要把AccessKey ID和AccessKey Secret保存到工程代碼里,否則可能導致AccessKey泄露,威脅您賬號下所有資源的安全。
    // 本示例通過從環境變量中讀取AccessKey,來實現API訪問的身份驗證。運行代碼示例前,請配置環境變量ALIBABA_CLOUD_ACCESS_KEY_ID和ALIBABA_CLOUD_ACCESS_KEY_SECRET。
    public static String accessKeyId = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_ID");
    public static String accessKeySecret = System.getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET");

    public static void main(String[] args) {


        try{
            DefaultAcsClient vodClient = initVodClient(accessKeyId, accessKeySecret);
            //視頻ID
            String videoId = "a42bf540b1b37*******b79f0102";

            //場景一:有回調服務 或 MNS
            //若是為新上傳的視頻設置封面,則需要先獲取到音視頻分析成功事件
            //若是為存量視頻設置封面,則可以直接從此步驟開始提交截圖任務
            submitSnapshotJob(vodClient,videoId);

            //獲取到視頻截圖成功事件,判斷截圖類型,取得需要的圖片URL
            JSONObject callBackMessage = new JSONObject();  //此處替換為回調服務收到的message
            String snapshotType = callBackMessage.getJSONObject("UserData").getJSONObject("Extend").getString("SnapshotType");
            if("FirstFrame".equals(snapshotType)){

                //這里的截圖路徑邏輯需要根據您自行定義的截圖路徑邏輯來替換
                String coverUrl = callBackMessage.getJSONArray("SnapshotInfos").getJSONObject(0).getString("SnapshotRegular").replace("{SnapshotCount}","00001");
                //修改視頻封面
                updateVideoInfo(vodClient,videoId,coverUrl);
            }

            //場景二:無回調服務 或 MNS
            //若是為新上傳的視頻設置封面,則視頻上傳后,輪詢視頻狀態
            String videoStatus = "";
            while(!"Normal".equals(videoStatus)){
                videoStatus = getVideoInfo(vodClient,videoId);
                Thread.sleep(1000);
            }

            //若是為存量視頻設置封面,則可以直接從此步驟開始提交截圖任務
            submitSnapshotJob(vodClient,videoId);

            //輪詢截圖結果
            String coverUrl = "";
            while(StringUtils.isBlank(coverUrl)){
                coverUrl = listSnapshots(vodClient,videoId);
                Thread.sleep(1000);
            }

            //修改視頻封面
            updateVideoInfo(vodClient,videoId,coverUrl);
        }catch (Exception e){

        }
    }

    /**
     * 提交截圖任務
     */
    public static SubmitSnapshotJobResponse submitSnapshotJob(DefaultAcsClient vodClient, String vid) throws ClientException {
        SubmitSnapshotJobRequest request = new SubmitSnapshotJobRequest();
        request.setVideoId(vid);
        request.setSnapshotTemplateId("1f27a7f*********70eba2756");
        //自定義透傳參數,回調時可用,非必須,用于區分封面首幀截圖
        request.setUserData("{\"Extend\":{\"SnapshotType\":\"FirstFrame\",\"VideoId\":\"a42bf540********33b79f0102\"}}");

        return vodClient.getAcsResponse(request);
    }

    /**
     * 修改視頻封面
     */
    public static UpdateVideoInfoResponse updateVideoInfo(DefaultAcsClient vodClient, String vid, String coverUrl) throws ClientException {
        UpdateVideoInfoRequest request = new UpdateVideoInfoRequest();
        request.setVideoId(vid);
        //設置首幀封面時,CoverURL為首幀截圖任務成功后輸出的圖片地址
        request.setCoverURL(coverUrl);

        return vodClient.getAcsResponse(request);
    }

    /**
     * 初始化sdk實例
     */
    public static DefaultAcsClient initVodClient(String accessKeyId, String accessKeySecret) throws ClientException {
        // 點播服務接入區域
        String regionId = "cn-shanghai";  
        DefaultProfile profile = DefaultProfile.getProfile(regionId, accessKeyId, accessKeySecret);
        DefaultAcsClient client = new DefaultAcsClient(profile);

        return client;
    }

    /**
     * 查詢截圖
     */
    public static String listSnapshots(DefaultAcsClient vodClient, String vid) throws ClientException {
        ListSnapshotsRequest request = new ListSnapshotsRequest();
        request.setVideoId(vid);
        request.setSnapshotType("NormalSnapshot");

        ListSnapshotsResponse response = vodClient.getAcsResponse(request);
        String coverUrl = "";
        System.out.println("RequestId is:" + response.getRequestId());
        try{
            coverUrl = response.getMediaSnapshot().getSnapshots().get(0).getUrl();
            System.out.println("SnapshotUrl is:" + response.getMediaSnapshot().getSnapshots().get(0).getUrl());
        }catch (NullPointerException e){

        }
        return coverUrl;
    }

    /**
     * 查詢單個視頻
     */
    public static String getVideoInfo(DefaultAcsClient vodClient, String vid) throws ClientException {
        GetVideoInfoRequest request = new GetVideoInfoRequest();
        request.setVideoId(vid);

        GetVideoInfoResponse response = vodClient.getAcsResponse(request);
        System.out.println("RequestId is:" + response.getRequestId());
        String videoStatus = "";
        try{
            videoStatus = response.getVideo().getStatus();
            System.out.println("Video Status is:" + response.getVideo().getStatus());
        }catch (NullPointerException e){

        }

        return videoStatus;
    }
}

步驟三:(可選)預熱視頻資源

通過視頻點播的預熱功能,將視頻資源提前緩存到CDN節點上,用戶請求播放視頻時,可以直接從CDN節點獲取到最新的資源,無需再回源站獲取,從而提升用戶請求播放的響應速度,有利于播放器預加載的實現。

說明

由于刷新預熱有一定的回源流量成本,可根據視頻熱度進行預熱,將視頻主動預熱在阿里云各個節點上。

控制臺方式配置

  1. 登錄視頻點播控制臺

  2. 在左側導航欄選擇配置管理 > 分發加速配置 > 刷新預熱,進入到刷新預熱頁面。

  3. 刷新緩存頁簽,配置預熱信息。

    • 操作類型:選擇預熱

    • 刷新類型:固定為URL

    • URL:輸入待預熱的視頻資源的URL。輸入的URL必須帶有http://https://。同一個賬號每天最多預熱500個URL,每次最多只能提交100條。

  4. 單擊提交,完成預熱配置。

OpenAPI方式配置

  1. 調用PreloadVodObjectCaches - 預熱緩存接口實現預熱視頻資源。

步驟四:使用阿里云播放器播放視頻

使用阿里云播放器通過UrlSource方式播放視頻。