七牛视频切片方案

使用七牛 sdk 上传视频并做分片操作。

step1 生成 token

const qiniu = require("qiniu");

var accessKey = proc.env.QINIU_ACCESS_KEY;
var secretKey = proc.env.QINIU_SECRET_KEY;
var mac = new qiniu.auth.digest.Mac(accessKey, secretKey);

var bucket = proc.env.QINIU_TEST_BUCKET;  // 对象存储空间

//带数据处理的凭证
var origin_filename = "avthumb_test_target.mp4";  // 源文件名
var save_as_filename = `${origin_filename}.m3n8`;  // 分片后的文件名

var saveMp4Entry = qiniu.util.urlsafeBase64Encode(`${bucket}:${save_as_filename}`);
var avthumbMp4Fop = "avthumb/m3u8/noDomain/1/segtime/15/vb/440k|saveas/" + saveMp4Entry;

var options = {
  scope: bucket,
  expires: 3600,  // 凭证有效时间
  persistentOps: avthumbMp4Fop,  // 视频上传后触发预转持久化,切片处理
  persistentPipeline: "video-pipe",  // 多媒体处理队列
  persistentNotifyUrl: "http://api.example.com/qiniu/pfop/notify",  // 回调通知地址
}
var putPolicy = new qiniu.rs.PutPolicy(options);
console.log(putPolicy.uploadToken(mac));

生成不同作用的凭证可以查看官方提供的示例nodejs-sdk example

以上代码为生成上传视频并进行切片处理的凭证。上传相关的文档查看七牛上传策略

切片动作是由persistentOps参数触发并启动一个异步任务,

persistentOps 详解

persistentOps 字段用于指定预转数据处理命令和保存处理结果的存储空间与资源名。

为此字段指定非空值,则在成功上传一个文件后,会启动一个异步数据处理任务persistentId 字段,唯一标识此任务。

returnBody 中指定了 persistentId 魔法变量时,客户端收到的响应内容 returnBody 中会有 persistentId;当没有指定 returnBody 时,默认也会返回 persistentId

  • 使用默认的存储空间和资源名

    * 当只指定了数据处理命令时,服务端会选择上传文件的 Bucket 作为数据处理结果的存储空间,Key 由七牛服务器自动生成。

  • 使用指定的存储空间和资源名
    • 在数据处理命令后用管道符|拼接saveas/<encodedEntryURI>指令,指示七牛服务器使用EncodedEntryURI格式中指定的 Bucket 与 Key 来保存处理结果。如 avthumb/flv|saveas/cWJ1Y2tldDpxa2V5,是将上传的视频文件转码flv格式后存储为qbucket:qkey,其中cWJ1Y2tldDpxa2V5qbucket:qkeyURL安全的Base64编码结果。以上方式可以同时作用于多个数据处理命令,用;分隔,如 avthumb/mp4|saveas/cWJ1Y2tldDpxa2V5;avthumb/flv|saveas/cWJ1Y2tldDpxa2V5Mg==

摘自七牛上传凭证

数据处理命令可以查看官方文档,比如视频切片接口

step2 前端直传

POST http://up.qiniu.com
格式: form-data
参数:
key: 文件名,上文代码中的 `origin_filename`
token: 上传token
file: 具体文件

// 上传成功的响应体
// 状态码 200
{
    "hash": "luVJbz9RtE3Ha7c9XaDerE6rPyvP",
    "key": "prTEDwvJY18YBD_720_p1.mp4",
    "persistentId": "z0.5b56c9b938b9f324a573edb4" // 可以使用persistentId,检测当前处理状态
}

作者:youthcity
链接:https://www.jianshu.com/p/f73b39ae02dc
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

step3 轮询获取结果

GET api.qiniu.com/status/get/prefop?id=${persistentId}

{
    "code": 0, //   状态码0成功,1等待处理,2正在处理,3处理失败,4通知提交失败。
    "desc": "The fop was completed successfully",
    "id": "z0.5b56c9b938b9f324a573edb4",
    "inputBucket": "ocean",
    "inputKey": "prTEDwvJY18YBD_720_p1.mp4",
    "items": [
        {
            "cmd": "avthumb/m3u8/noDomain/1/segtime/15/vb/440k|saveas/b2NlYW46aGxzX3ByVEVEd3ZKWTE4WUJEXzcyMF9wMS5tM3U4",
            "code": 0,
            "desc": "The fop was completed successfully",
            "hash": "FraV6PX6Xp7mYYgAnY0sniTK-pPt",
            "key": "hls_prTEDwvJY18YBD_720_p1.m3u8",
            "returnOld": 0
        }
    ],
    "pipeline": "1381326751.k12_video",
    "reqid": "FQIAAKAxpZfFOkQV"
}

作者:youthcity
链接:https://www.jianshu.com/p/f73b39ae02dc
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

参考资料

七牛上传凭证

七牛上传策略

视频切片接口

七牛上传开发(三)使用NodeJS生成带数据处理的凭证

nodejs-sdk example

原文地址:https://www.cnblogs.com/chaohangz/p/9824802.html

时间: 2024-10-09 02:36:49

七牛视频切片方案的相关文章

七牛用户如何将视频转码成普清高清来适应不同的手机端或者web端

Qiniu 七牛问题解答 非常多人会用到七牛视频转码问题,要将视频转码成适用于各种终端的视频,也有的用户对转码服务的码率,帧率,分辨率等理解不多.不知道该怎样设置这些參数.以下我给大家科普一下. 问题解决方式 1,我们在七牛后台提供了各种转码的有用參数.大家能够看下: 假设你想要查看上面图片中各种处理样式的内容能够选中后,在以下会有參数的设定字符串. 2,用户存在一个误区,就是他并不知道码率,和帧率等參数的设定,事实上你用七牛转码的时候,转成某类的视频格式,是採用默认的码率等信息的.不用特定的去

七牛用户怎样将视频转码成普清高清来适应不同的手机端或者web端

Qiniu 七牛问题解答 很多人会用到七牛视频转码问题,要将视频转码成适用于各种终端的视频,也有的用户对转码服务的码率,帧率,分辨率等理解不多.不知道该如何设置这些参数.下面我给大家科普一下. 问题解决方案 1,我们在七牛后台提供了各种转码的实用参数.大家可以看下: 如果你想要查看上面图片中各种处理样式的内容可以选中后,在下面会有参数的设定字符串. 2,用户存在一个误区,就是他并不知道码率,和帧率等参数的设定,其实你用七牛转码的时候,转成某类的视频格式,是采用默认的码率等信息的.不用特定的去设置

七牛的存储算法猜测

个人浏览网页的时候,有打标签的习惯.最近整理以往的标签的时候,发现积累了一些有关七牛公司存储策略的网页,遂决定整理一篇文章处理,以备记忆.当然,也希望对他人有用. 因为七牛公司的存储策略主要基于纠删码(Erasure Codes,EC),所以下面先从纠删码引申开来. 引言:何为纠删码 数据的爆炸式增长使得存储系统的规模不断增加,存储设备的可靠性却一直没有得到显著提高(SSD 从SLC 到MLC 和TLC 可靠性不断下降,磁盘随着单位面积写入数据更多导致可靠性无法提升),从而给数据的持久化存储带来

七牛上传视频并转码

/// <summary> /// 上传视频到七牛并转码 /// </summary> /// <param name="saveKey"></param> /// <param name="localFile"></param> public static void UpLoadVideo(string saveKey, string localFile) { Mac mac = new Ma

七牛音视频服务价格正式下调,让富媒体成为应用标配

2014被称为移动短视频元年,借着4G牌照发放的东风,曾受限于带宽和流量的富媒体领域春潮涌动.腾讯微视.新浪秒拍提前布局,微拍.微录客.啪啪奇.微可拍等应用如雨后春笋.明星应用"美拍"横空出世,提供60秒短视频分享,仅9个月就成功获取上亿用户. 传播学大师麦克卢汉认为,"媒介是人的延伸",20世纪以来诞生的电子媒介,是人类中枢神经系统,和现实世界感知整合的产物.媒介向前进化的每一步,都是对人类认知边界的一次拓宽. 回顾网络时代电子媒介发展史,文字和链接构建起最初的W

关于在七牛使用过程中视频播放器的推荐方案

Qiniu 七牛问题解答 很多七牛用户在使用七牛云存储过程中遇到视频播放器选择的问题,这里我做下简单的推荐. 音视频支持 音视频播放 在依托七牛云存储建立视频应用的过程中,使用者时常遇到播放的问题:选择什么样的播放器?使用什么样的编码和容器格式?如何适应多种客户端?等等. 播放器的要求 视频应用通常要求播放器具备以下的基本特性: 多客户端支持.包括:PC端(Web播放)和移动端(iOS,Android等).具备多平台支持的播放器有助于简化开发,规避平台之间的差异. 常用的音视频编码格式支持.常用

七牛音视频转码-分辨率,码率,帧率,清晰度的联系和区别

Qiniu 七牛问题解答 名词介绍 1,码率:"码率"就是失真度,码率越高越清晰,反之则画面粗糙而多马赛克."码率是指每秒传送的比特(bit)数.单位为 bps(Bit Per Second),比特率越高,传送数据速度越快.声音中的比特率是指将模拟声音信号转换成数字声音信号后,单位时间内的二进制数据量,是间接衡量音频质量的一个指标. 视频中的比特率(码率)原理与声音中的相同,都是指由模拟信号转换为数字信号后,单位时间内的二进制数据量. 2,分辨率:分辨率可以从显示分辨率与图像

七牛上传视频添加到队列时视频大小是否添加

最近在做视频分析的项目,遇到了一些关于七牛上传视频文件的问题. 当 选择的视频文件 大于 本地剩余空间 时,则取消上传. 'FilesAdded': function(up, files) { plupload.each(files, function(file,index) { //重点在这里 var fileSize=0; for(var i=0;i<files.length;i++){ fileSize+= Math.ceil(files[i].size/1024/1024); }; //

关于上传视频到七牛的一些解决方案

<div class="form-group"> <label>上传视频:</label> <div class="my-upload"> <div class=""> <input type="file" id="fileupload" name="fileupload" class="" />