Java:將視頻上傳到騰訊云并通過騰訊云點播播放

功能需求:

傳入一個videoFile也就是視頻字節流,返回騰訊云點播的視頻保存url

需要在騰訊云中尋找的配置信息:

導入的依賴:

<!--騰訊云點播--><dependency><groupId>com.tencentcloudapi</groupId><artifactId>tencentcloud-sdk-java</artifactId><version>4.0.11</version></dependency><!--騰訊云cos--><dependency><groupId>com.qcloud</groupId><artifactId>cos_api</artifactId><version>5.6.54</version></dependency>

大體分為兩步:


1.將視頻上傳到騰訊云

我們借助騰訊云依賴提供的cos客戶端,將騰訊云的id,秘鑰等配置信息傳入,再將文件信息配置到cos客戶端,發送請求,生成這個視頻的訪問路徑

2.騰訊云點播保存騰訊云中我們剛剛上傳的視頻并返回一個播放改視頻的url

同理,借助VOD客戶端上傳對應視頻

全部源代碼

package net.mingsoft.cms.biz.impl;import com.qcloud.cos.COSClient;
import com.qcloud.cos.ClientConfig;
import com.qcloud.cos.auth.BasicCOSCredentials;
import com.qcloud.cos.auth.COSCredentials;
import com.qcloud.cos.http.HttpProtocol;
import com.qcloud.cos.model.ObjectMetadata;
import com.qcloud.cos.model.PutObjectRequest;
import com.qcloud.cos.region.Region;
import com.tencentcloudapi.common.Credential;
import com.tencentcloudapi.common.exception.TencentCloudSDKException;
import com.tencentcloudapi.common.profile.ClientProfile;
import com.tencentcloudapi.common.profile.HttpProfile;
import com.tencentcloudapi.vod.v20180717.VodClient;
import com.tencentcloudapi.vod.v20180717.models.*;
import net.mingsoft.base.biz.impl.BaseBizImpl;
import net.mingsoft.base.dao.IBaseDao;
import net.mingsoft.cms.biz.IVideoBiz;
import net.mingsoft.cms.dao.IVideoDao;
import net.mingsoft.cms.entity.VideoEntity;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;import java.io.IOException;
import java.io.InputStream;
import java.util.UUID;/*** 視頻管理服務實現類(集成COS上傳與云點播同步)* 提供視頻上傳到騰訊云COS并同步到云點播服務功能*/
@Service("cmsVideoBizImpl")
public class VideoBizImpl extends BaseBizImpl<IVideoDao, VideoEntity> implements IVideoBiz {private static final Logger log = LoggerFactory.getLogger(VideoBizImpl.class);// 騰訊云配置信息 - 需要從配置文件或環境變量中獲取private static final String SECRET_ID = "YOUR_TENCENT_CLOUD_SECRET_ID";private static final String SECRET_KEY = "YOUR_TENCENT_CLOUD_SECRET_KEY";private static final String BUCKET_NAME = "your-bucket-name";private static final String BUCKET_REGION = "ap-region-1";private static final String COS_DOMAIN = "your-bucket.cos.ap-region-1.myqcloud.com";// 云點播配置private static final String VOD_REGION = "ap-region-1";private static final Long VOD_SUB_APP_ID = 1000000L;/*** 上傳視頻文件到騰訊云并同步到云點播* @param videoFile 視頻文件* @return 云點播播放URL* @throws IOException 文件讀取異常*/@Overridepublic String uploadVideo(MultipartFile videoFile) throws IOException {// 1. 初始化COS客戶端COSCredentials cosCred = new BasicCOSCredentials(SECRET_ID, SECRET_KEY);ClientConfig clientConfig = new ClientConfig(new Region(BUCKET_REGION));clientConfig.setHttpProtocol(HttpProtocol.https);try (COSClient cosClient = new COSClient(cosCred, clientConfig)) {// 2. 處理文件信息String originalFilename = videoFile.getOriginalFilename();String fileExtension = originalFilename.substring(originalFilename.lastIndexOf("."));// 添加目錄前綴便于管理String newFileName = "videos/" + UUID.randomUUID() + fileExtension;// 3. 上傳文件到COStry (InputStream inputStream = videoFile.getInputStream()) {ObjectMetadata metadata = new ObjectMetadata();metadata.setContentLength(videoFile.getSize());metadata.setContentType(videoFile.getContentType());PutObjectRequest putObjectRequest = new PutObjectRequest(BUCKET_NAME,newFileName,inputStream,metadata);cosClient.putObject(putObjectRequest);}log.info("視頻已成功上傳到COS,路徑:{}", newFileName);// 4. 生成COS訪問URLString cosUrl = "https://" + COS_DOMAIN + "/" + newFileName;// 5. 同步到云點播并獲取播放鏈接String playUrl = syncToVod(cosUrl, originalFilename);log.info("視頻已成功同步到云點播,播放URL: {}", playUrl);return playUrl;} catch (TencentCloudSDKException e) {log.error("云點播API調用失敗", e);throw new RuntimeException("視頻處理失敗:" + e.getMessage());}}/*** 將COS視頻同步到云點播并獲取播放鏈接* @param cosUrl COS視頻URL* @param originalFilename 原始文件名* @return 云點播播放URL*/private String syncToVod(String cosUrl, String originalFilename) throws TencentCloudSDKException {// 1. 初始化VOD客戶端Credential cred = new Credential(SECRET_ID, SECRET_KEY);HttpProfile httpProfile = new HttpProfile();httpProfile.setEndpoint("vod.tencentcloudapi.com");ClientProfile clientProfile = new ClientProfile();clientProfile.setHttpProfile(httpProfile);try (VodClient vodClient = new VodClient(cred, VOD_REGION, clientProfile)) {// 2. 拉取上傳到云點播PullUploadRequest pullRequest = new PullUploadRequest();pullRequest.setMediaUrl(cosUrl);pullRequest.setMediaName(originalFilename);pullRequest.setSubAppId(VOD_SUB_APP_ID);log.info("開始拉取上傳視頻到云點播,COS URL: {}", cosUrl);// 3. 執行拉取上傳PullUploadResponse pullResponse = vodClient.PullUpload(pullRequest);String taskId = pullResponse.getTaskId();log.info("云點播拉取上傳任務已創建,任務ID: {}", taskId);// 4. 等待任務完成并獲取文件IDString fileId = waitForTaskCompletion(vodClient, taskId);if (fileId == null) {throw new RuntimeException("云點播任務處理超時或失敗");}log.info("視頻已成功同步到云點播,文件ID: {}", fileId);// 5. 獲取播放URLreturn getPlayUrl(vodClient, fileId);}}/*** 等待云點播任務完成*/private String waitForTaskCompletion(VodClient vodClient, String taskId) throws TencentCloudSDKException {int maxRetries = 30; // 最大重試次數int retryInterval = 2000; // 重試間隔2秒for (int i = 0; i < maxRetries; i++) {try {Thread.sleep(retryInterval);DescribeTaskDetailRequest taskRequest = new DescribeTaskDetailRequest();taskRequest.setTaskId(taskId);taskRequest.setSubAppId(VOD_SUB_APP_ID);DescribeTaskDetailResponse taskResponse = vodClient.DescribeTaskDetail(taskRequest);String status = taskResponse.getStatus();if ("FINISH".equals(status)) {PullUploadTask pullUploadTask = taskResponse.getPullUploadTask();if (pullUploadTask != null) {return pullUploadTask.getFileId();} else {throw new RuntimeException("無法獲取PullUploadTask信息");}} else if ("FAIL".equals(status)) {throw new RuntimeException("云點播任務處理失敗");}} catch (InterruptedException e) {Thread.currentThread().interrupt();throw new RuntimeException("任務等待被中斷", e);}}throw new RuntimeException("云點播任務處理超時");}/*** 獲取視頻播放URL*/private String getPlayUrl(VodClient vodClient, String fileId) throws TencentCloudSDKException {DescribeMediaInfosRequest mediaRequest = new DescribeMediaInfosRequest();mediaRequest.setFileIds(new String[]{fileId});mediaRequest.setSubAppId(VOD_SUB_APP_ID);DescribeMediaInfosResponse mediaResponse = vodClient.DescribeMediaInfos(mediaRequest);if (mediaResponse.getMediaInfoSet() == null || mediaResponse.getMediaInfoSet().length == 0) {throw new RuntimeException("未找到視頻信息,文件ID: " + fileId);}MediaInfo mediaInfo = mediaResponse.getMediaInfoSet()[0];return mediaInfo.getBasicInfo().getMediaUrl();}/*** 獲取轉碼后的播放URL(可選)*/private String getTranscodePlayUrl(VodClient vodClient, String fileId) throws TencentCloudSDKException {DescribeMediaInfosRequest mediaRequest = new DescribeMediaInfosRequest();mediaRequest.setFileIds(new String[]{fileId});mediaRequest.setSubAppId(VOD_SUB_APP_ID);DescribeMediaInfosResponse mediaResponse = vodClient.DescribeMediaInfos(mediaRequest);return mediaResponse.getMediaInfoSet()[0].getBasicInfo().getMediaUrl();}@Overrideprotected IBaseDao<VideoEntity> getDao() {return null;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/93812.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/93812.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/93812.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Unity3D物理游戲網絡同步指南

前言 Unity3D 物理游戲的網絡同步是一個復雜但非常核心的話題。要實現一個流暢、公平且可擴展的多人物理游戲&#xff0c;需要深入的理解和精心的設計。 下面我將為你全面解析 Unity3D 物理游戲的網絡同步&#xff0c;包括核心概念、主流方案、實現細節以及最佳實踐。 對惹&…

Amazon Redshift 訪問配置完整指南

概述 Amazon Redshift 是 AWS 提供的云端數據倉庫服務,支持多種訪問方式。本文將詳細介紹如何配置 IAM 權限、使用 AWS 控制臺 Query Editor v2,以及通過 SQL Workbench/J 等第三方工具連接 Redshift 集群。 目錄 環境準備 IAM 權限配置 Redshift 用戶管理 AWS 控制臺訪問 …

electron-vite_19配置環境變量

前端配罟環境變量主要通過項目根目錄下的.env系列文件實現&#xff0c;不同框架(如Vue、React)或構建工具(如Vite、Webpack)的具體操作略有差異&#xff0c;但核心邏輯均為通過環境變量文件區分開發、測試、生產等環境。方案1: 直接在根目錄新建.env文件 1.在根目錄新建 .env.d…

【python】arange用法

1. NumPy 里的 np.arangeimport numpy as np# 語法 np.arange([start, ]stop, [step, ], dtypeNone)參數說明&#xff1a;start&#xff1a;起始值&#xff08;默認 0&#xff09;stop&#xff1a;終止值&#xff08;不包含這個值&#xff09;step&#xff1a;步長&#xff08;…

力扣1005:k次取反后最大化的數組和

力扣1005:k次取反后最大化的數組和題目思路代碼題目 給你一個整數數組 nums 和一個整數 k &#xff0c;按以下方法修改該數組&#xff1a; 選擇某個下標 i 并將 nums[i] 替換為 -nums[i] 。 重復這個過程恰好 k 次。可以多次選擇同一個下標 i 。 以這種方式修改數組后&…

國產數據庫管理工具 CloudDM 2.7.1.0 發布,OceanBase 等數據源支持復雜 SQL 脫敏數據

CloudDM 是 ClouGence 公司推出的面向團隊使用的數據庫管理工具&#xff0c;支持云上、云下、多云等多種環境&#xff0c;并且提供多達 23 種數據源的支持。CloudDM 還支持數據庫 DevOps CI/CD 功能&#xff0c;將用戶產品發布流程中數據庫發布和程序發布無縫串聯起來。 更新亮…

AI大模型實戰:用自然語言處理技術高效處理日常瑣事

引言在數字化時代&#xff0c;我們每天都會面對大量的瑣碎事務&#xff1a;整理會議記錄、處理名單數據、撰寫學習筆記等等。這些工作不僅耗時&#xff0c;而且容易出錯。幸運的是&#xff0c;隨著人工智能技術的發展&#xff0c;特別是大語言模型&#xff08;LLM&#xff09;的…

【spring security】為什么要使用userdetailservice

Spring Security UserDetailsService 深度解析&#xff1a;從401到認證成功的完整實現 &#x1f4cb; 目錄 問題背景Spring Security認證架構UserDetailsService的作用完整實現過程常見問題與解決方案最佳實踐 &#x1f3af; 問題背景 在開發B2B采購平臺時&#xff0c;我們…

機器學習中的數據處理技巧

一、Pandas處理丟失數據&#xff08;一&#xff09;判斷缺失值??isnull()函數??&#xff1a;用于判斷數據框&#xff08;DataFrame&#xff09;中各個單元格是否為空&#xff0c;可幫助我們識別出存在缺失數據的單元格位置。&#xff08;二&#xff09;處理缺失值的方法??…

田野科技“一張皮”,“AI+虛擬仿真”推動考古教學創新發展

文運同國運相牽&#xff0c;文脈同國脈相連。考古不僅關系到我們對古代文化的認知、發掘、保護、利用&#xff0c;關系到考古學學科體系、學術體系、話語體系的建設&#xff0c;更是關系到我國考古學的國際影響力&#xff0c;對增強世界不同地區古代文明的比較研究有著十分重要…

為什么我的UI界面會突然卡頓,失去響應

有操作都應是“非阻塞”的&#xff0c;以確保能隨時響應用戶的輸入。導致主線程阻塞的常見“元兇”主要涵蓋五個方面&#xff1a;主線程被“長時間”的同步計算所“阻塞”、單次渲染的界面節點過多或過于復雜、內存中存在“未釋放”的巨大對象或“內存泄漏”、響應了“高頻率”…

大規模IP輪換對網站的影響(服務器壓力、風控)

在當下的互聯網環境中&#xff0c;代理IP輪換已經成為爬蟲、SEO、數據采集等行業的常見手段。尤其是大規模數據抓取時&#xff0c;通過代理池實現IP輪換&#xff0c;可以有效避免因單一IP請求過于頻繁而被目標網站封禁。 然而&#xff0c;大規模IP輪換雖然對采集方有利&#xf…

4. STM32 vscode 環境, 官方插件

文章目錄1. 新建配置2. 安裝插件3. 新建工程1. 新建配置 新建vscode 配置&#xff0c; 因為stm32插件比較多&#xff0c; 避免和其他插件沖突。 激活環境&#xff1a; 這里可快速切換&#xff1a; 2. 安裝插件 可選擇安裝最新預覽版&#xff1a; 等待依賴安裝完成后重啟…

【動態規劃:路徑問題】最小路徑和 地下城游戲

最小路徑和&#xff08;medium&#xff09; 64. 最小路徑和 ? 給定一個包含非負整數的 m x n 網格 grid &#xff0c;請找出一條從左上角到右下角的路徑&#xff0c;使得路徑上的數字總和為最小。 ? **說明&#xff1a;**每次只能向下或者向右移動一步。 示例 1&#xff…

SQL詳細語法教程(七)核心優化

以下對 SQL 優化 涉及的關鍵場景&#xff08;含 update 行鎖優化&#xff09;進行極致詳細的拆解&#xff0c;從底層原理、執行流程到實戰代碼、避坑指南全維度覆蓋&#xff0c;搭配表格對比讓邏輯更清晰&#xff1a;一、SQL 優化 - COUNT 優化1. 底層原理&#xff1a;COUNT() …

Tomcat 的核心腳本catalina.sh 和 startup.sh的關系

catalina.sh 和 startup.sh 都是 Tomcat 的核心腳本&#xff0c;但它們的角色和使用場景有所不同。以下是它們的主要區別和適用場景&#xff1a;1. 功能區別腳本主要用途底層調用關系startup.sh一個快捷入口腳本&#xff0c;用于快速啟動 Tomcat&#xff08;后臺模式&#xff0…

飛算JavaAI:簡易貪吃蛇小游戲

目錄先確定核心功能技術選型核心功能實現過程1. 數據模型設計2. 游戲界面和繪制邏輯3. 游戲主框架和事件處理飛算JavaAI在開發中的應用體驗可以進一步優化的地方作為Java課程的小作業&#xff0c;不想做太復雜的管理系統&#xff0c;就選了貪吃蛇這個經典小游戲。全程用Swing做…

如何保障內部網絡安全前提下,實現與外部互聯網之間的文件傳輸?

在數字化時代&#xff0c;企業網絡環境日益復雜&#xff0c;普遍采用“內外網隔離”的安全架構&#xff1a;內部辦公網承載業務系統與數據&#xff0c;外部互聯網則用于對外溝通與信息獲取。這種隔離有效抵御了外部攻擊&#xff0c;但也帶來了“信息孤島”問題——如何在保障內…

計算機視覺 圖片處理 在骨架化過程中,每次迭代都會從圖像的邊緣移除一層像素,直到只剩下單像素寬度的骨架

你說得對&#xff0c;if cv2.countNonZero(binary) 0: break 這個條件確實表示圖像中已經沒有非零像素&#xff0c;即圖像完全變為空白。這并不是骨架化完成的標志&#xff0c;而是表示圖像已經被腐蝕到沒有任何內容了。 在骨架化過程中&#xff0c;我們需要一個更合適的停止條…

rt-thread audio框架移植stm32 adc+dac,用wavplayer錄音和播放

D1 參考 rt-thread官方sdk中&#xff0c;正點原子stm32f429-atk-appollo的board中有audio文件夾&#xff0c;包括了mic/play的程序&#xff0c;wm8978的庫文件因為我們基于stm32h750內置adcdac設計&#xff0c;所以不需要wm8978.c/h。只需要移植drv_sound.c和drv_mic.c D2 工程…