七牛視頻切片方案


使用七牛 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.jianshu.com/u/13cd86311525


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM