腾讯云 上传视频_云点播系统源码

腾讯云 上传视频_云点播系统源码 web利用腾讯云点播上传视频到云服务器第一步导入<scriptsrc="//imgcache.qq.com/open/qcloud/js/vod/sdk/ugcUploader.js"></script>第二步在服务端设置秘钥,我用的是javaee编写一个Signature类 所需jar包http://download.csdn.net/down…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

 

web利用腾讯云点播上传视频到云服务器

第一步导入

<script src="//imgcache.qq.com/open/qcloud/js/vod/sdk/ugcUploader.js"></script>

Jetbrains全家桶1年46,售后保障稳定

第二步在服务端设置秘钥,我用的是javaee 编写一个Signature类 

所需jar包http://download.csdn.net/download/sinat_36596988/10195891

import javax.crypto.Mac;

import javax.crypto.spec.SecretKeySpec;
import Decoder.BASE64Encoder;


public class Signature {
private String secretId;
private String secretKey;
private long currentTime;
private int random;
private int signValidDuration;


private static final String HMAC_ALGORITHM = "HmacSHA1";
private static final String CONTENT_CHARSET = "UTF-8";


public static byte[] byteMerger(byte[] byte1, byte[] byte2) {
byte[] byte3 = new byte[byte1.length + byte2.length];
System.arraycopy(byte1, 0, byte3, 0, byte1.length);
System.arraycopy(byte2, 0, byte3, byte1.length, byte2.length);
return byte3;
}
public String getUploadSignature() throws Exception {
String strSign = "";
String contextStr = "";


long endTime = (currentTime + signValidDuration);
contextStr += "secretId=" + java.net.URLEncoder.encode(secretId, "utf8");
contextStr += "¤tTimeStamp=" + currentTime;
contextStr += "&expireTime=" + endTime;
contextStr += "&random=" + random;
try {
Mac mac = Mac.getInstance(HMAC_ALGORITHM);
SecretKeySpec secretKey = new SecretKeySpec(this.secretKey.getBytes(CONTENT_CHARSET), mac.getAlgorithm());
mac.init(secretKey);
byte[] hash = mac.doFinal(contextStr.getBytes(CONTENT_CHARSET));
byte[] sigBuf = byteMerger(hash, contextStr.getBytes("utf8"));
strSign = new String(new BASE64Encoder().encode(sigBuf).getBytes());
strSign = strSign.replace(" ", "").replace("\n", "").replace("\r", "");
} catch (Exception e) {
throw e;
}
return strSign;
}


public void setSecretId(String secretId) {
this.secretId = secretId;
}


public void setSecretKey(String secretKey) {
this.secretKey = secretKey;
}


public void setCurrentTime(long currentTime) {
this.currentTime = currentTime;
}


public void setRandom(int random) {
this.random = random;
}


public void setSignValidDuration(int signValidDuration) {
this.signValidDuration = signValidDuration;
}
}
//通过shangchuan.do方法得到秘钥
//APPID APPKEY 进入腾讯云控制台获取https://console.cloud.tencent.com/cam/capi
@RequestMapping("shangchuan.do")
	@ResponseBody
	public String shangchuan(Model model){
		Signature sign = new Signature();
		sign.setSecretId("你的APPID");
		sign.setSecretKey("你的APPKEY");
		sign.setCurrentTime(System.currentTimeMillis() / 1000);
		sign.setRandom(new Random().nextInt(java.lang.Integer.MAX_VALUE));
		sign.setSignValidDuration(3600 * 24 * 2);


		try {
			String signature = sign.getUploadSignature();
			//System.out.println("signature : " + signature);
			return signature;
		} catch (Exception e) {			
			e.printStackTrace();
			return "获取签名失败";
		}
	}

 

 

 

 

 

第三步通过ajax方法得到秘钥并且上传
<html> <head> <title>My JSP 'shang.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <script src="//imgcache.qq.com/open/qcloud/js/vod/sdk/ugcUploader.js"></script> <script src="js/jquery.min.js"></script> </head> <body> <form id="form1"> <input id="uploadVideoNow-file" type="file" /> </form> </body> </html> <script> var getSignature = function(callback) { $.ajax({ url : "shangchuan.do", //服务器获取客户端上传签名的URL type : "POST", success : function(result) { //result.returnData.signature为获取到的签名 callback(result); //callback(result.returnData.signature); } }); }; $('#uploadVideoNow-file').on('change', function(e) { var videoFile = this.files[0]; var resultMsg = qcVideo.ugcUploader.start({ videoFile : videoFile, getSignature : getSignature, allowAudio : 1, isTranscode: 1, success : function(result) { alert("上传成功"); }, error : function(result) { alert("上传失败"); }, progress : function(result) { alert("上传进度:" + result.curr); }, finish : function(result) { alert("上传完成"); } }); }); </script>

具体事件https://cloud.tencent.com/document/product/266/9239 

然后登录腾讯云控制台的点播功能查看上传的视频 (需要转码成功后(会自动转码,需要一定时间))

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/222750.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月4日 上午8:43
下一篇 2025年7月4日 上午9:15


相关推荐

  • 拆解 OpenClaw 源码:1000 行代码复刻 AI Agent 核心架构

    拆解 OpenClaw 源码:1000 行代码复刻 AI Agent 核心架构

    2026年3月13日
    3
  • Solr入门指南

    Solr入门指南

    2021年12月31日
    35
  • PHPStorm2017.1.3永久激活方法之本地激活成功教程激活

    PHPStorm2017.1.3永久激活方法之本地激活成功教程激活是时候升级你的phpstorm了,咱们马上行动!下载1、phpstormhttps://www.jetbrains.com/phpstorm/download/2、激活成功教程包激活成功教程补丁无需使用注册码,下载

    2022年7月2日
    40
  • Django request对象

    Django request对象Djangorequest对象1简介服务器接收到http协议的请求后,会根据报文创建HttpRequest对象,这个对象不需要我们创建,直接使用服务器构造好的对象就可以。视图的第一个参数必须是HttpRequest对象,在django.http模块中定义了HttpRequest对象的API。2request对象的属性**request.scheme:**代表请求的方案,http或…

    2022年6月11日
    35
  • STM32编程怎么入门,聊聊我的入门经历

    STM32编程怎么入门,聊聊我的入门经历我第一次接触STM32大概是在8,9年前。当时刚出来工作不久,在此之前主要用stc和nxp的单片机比较多。那个时候还没有固件库开发的概念,基本都是配置寄存器去使用单片机外设资源。虽然说用起来比较麻烦,但是执行的效率也相对高一点,习惯了也挺好用。新项目比较复杂一点,一个老工程师建议我用stm32的单片机做效率比较高。听大佬的话照做是一个小菜鸟的基本素养,所以我选了stm32。对于学习这块,我也比较舍得(当时月薪只有1.8K),毫不犹豫花了几百大洋购买了一套stm32开发板。学习一款

    2025年9月29日
    3
  • C语言总结(一维数组、二维数组、字符数组和字符串)

    C语言总结(一维数组、二维数组、字符数组和字符串)C 语言总结第七章 数组一维数组一维数组的定义一维数组的引用一维数组的初始化程序举例二维数组及多维数组二维数组的定义二维数组元素的引用二维数组元素的初始化程序举例字符数组和字符串字符数组第七章 数组数组是构造数据类型之一数组 有序数据的集合 用数组名标识元素 属同一数据类型 用数组名和下标确定一维数组一维数组的定义定义方式 例 inta 6 一维数组的引用 1 数组

    2026年3月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号