久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

Node.js怎么實現(xiàn)分片上傳?方法介紹

Node怎么實現(xiàn)分片上傳?下面本篇文章給大家介紹一下Node.js實現(xiàn)分片上傳的方法,希望對大家有所幫助!

Node.js怎么實現(xiàn)分片上傳?方法介紹

大文件上傳會消耗大量的時間,而且中途有可能上傳失敗。這時我們需要前端和后端配合來解決這個問題。

解決步驟:

  • 文件分片,減少每次請求消耗的時間,如果某次請求失敗可以單獨上傳,而不是從頭開始

  • 通知服務(wù)端合并文件分片

  • 控制并發(fā)的請求數(shù)量,避免瀏覽器內(nèi)存溢出

  • 當(dāng)因為網(wǎng)絡(luò)或者其他原因?qū)е履炒蔚恼埱笫。覀冎匦掳l(fā)送請求

文件的分片與合并

在JavaScript中,F(xiàn)Ile對象是' Blob '對象的子類,該對象包含一個重要的方法slice,通過該方法我們可以這樣分割二進(jìn)制文件:

<!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <title>Document</title>     <script src="https://cdn.bootcdn.net/ajax/libs/axios/0.24.0/axios.min.js"></script> </head> <body>     <input type="file" multiple="multiple" id="fileInput" />     <button onclick="SliceUpload()">上傳</button>       <script>         function SliceUpload() {             const file = document.getElementById('fileInput').files[0]             if (!file) return              // 文件分片             let size = 1024 * 50; //50KB 50KB Section size             let fileChunks = [];             let index = 0;        //Section num             for (let cur = 0; cur < file.size; cur += size) {                 fileChunks.push({                     hash: index++,                     chunk: file.slice(cur, cur + size),                 });             }              // 上傳分片             const uploadList = fileChunks.map((item, index) => {                 let formData = new FormData();                 formData.append("filename", file.name);                 formData.append("hash", item.hash);                 formData.append("chunk", item.chunk);                 return axios({                     method: "post",                     url: "/upload",                     data: formData,                 });             });             await Promise.all(uploadList);              // 所有分片上傳完成,通知服務(wù)器合并分片             await axios({                 method: "get",                 url: "/merge",                 params: {                     filename: file.name,                 },             });             console.log("Upload to complete");         }     </script> </body> </html>

并發(fā)控制

如果文件很大,這樣切分的分片會很多,瀏覽器短時間內(nèi)就會發(fā)起大量的請求,可能會導(dǎo)致內(nèi)存耗盡,所以要進(jìn)行并發(fā)控制。

這里我們結(jié)合Promise.race()方法 控制并發(fā)請求的數(shù)量,避免瀏覽器內(nèi)存溢出。

// 加入并發(fā)控制 async function SliceUpload() {     const file = document.getElementById('fileInput').files[0]     if (!file) return      // 文件分片     let size = 1024 * 50; //50KB 50KB Section size     let fileChunks = [];     let index = 0;        //Section num     for (let cur = 0; cur < file.size; cur += size) {         fileChunks.push({             hash: index++,             chunk: file.slice(cur, cur + size),         });     }      let pool = []; //Concurrent pool     let max = 3; //Maximum concurrency     for (let i = 0; i < fileChunks.length; i++) {         let item = fileChunks[i];         let formData = new FormData();         formData.append("filename", file.name);         formData.append("hash", item.hash);         formData.append("chunk", item.chunk);          // 上傳分片         let task = axios({             method: "post",             url: "/upload",             data: formData,         });         task.then(() => {         // 從并發(fā)池中移除已經(jīng)完成的請求         let index = pool.findIndex((t) => t === task);             pool.splice(index);         });          // 把請求放入并發(fā)池中,如果已經(jīng)達(dá)到最大并發(fā)量         pool.push(task);         if (pool.length === max) {             //All requests are requested complete             await Promise.race(pool);         }     }      // 所有分片上傳完成,通知服務(wù)器合并分片     await axios({         method: "get",         url: "/merge",         params: {             filename: file.name,         },     });     console.log("Upload to complete"); }

使代碼可復(fù)用

function SliceUpload() {     const file = document.getElementById('fileInput').files[0]     if (!file) return      // 文件分片     let size = 1024 * 50; // 分片大小設(shè)置     let fileChunks = [];     let index = 0;        // 分片序號     for (let cur = 0; cur < file.size; cur += size) {         fileChunks.push({             hash: index++,             chunk: file.slice(cur, cur + size),         });     }      const uploadFileChunks = async function(list){         if(list.length === 0){             // 所有分片上傳完成,通知如無             await axios({                 method: 'get',                 url: '/merge',                 params: {                     filename: file.name                 }             });             console.log('Upload to complete')             return         }          let pool = []       // 并發(fā)池         let max = 3         // 最大并發(fā)數(shù)         let finish = 0      // 完成數(shù)量         let failList = []   // 失敗列表         for(let i=0;i<list.length;i++){             let item = list[i]             let formData = new FormData()             formData.append('filename', file.name)             formData.append('hash', item.hash)             formData.append('chunk', item.chunk)                          let task = axios({                 method: 'post',                 url: '/upload',                 data: formData             })              task.then((data)=>{                 // 從并發(fā)池中移除已經(jīng)完成的請求                 let index = pool.findIndex(t=> t===task)                 pool.splice(index)             }).catch(()=>{                 failList.push(item)             }).finally(()=>{                 finish++                 // 如果有失敗的重新上傳                 if(finish===list.length){                     uploadFileChunks(failList)                 }             })             pool.push(task)             if(pool.length === max){                 await Promise.race(pool)             }         }     }      uploadFileChunks(fileChunks) }

服務(wù)端接口實現(xiàn)

const express = require('express') const multiparty = require('multiparty') const fs = require('fs') const path = require('path') const { Buffer } = require('buffer') // file path const STATIC_FILES = path.join(__dirname, './static/files') // Temporary path to upload files const STATIC_TEMPORARY = path.join(__dirname, './static/temporary') const server = express() // Static file hosting server.use(express.static(path.join(__dirname, './dist'))) // Interface for uploading slices server.post('/upload', (req, res) => {     const form = new multiparty.Form();     form.parse(req, function(err, fields, files) {         let filename = fields.filename[0]         let hash = fields.hash[0]         let chunk = files.chunk[0]         let dir = `${STATIC_TEMPORARY}/${filename}`         // console.log(filename, hash, chunk)         try {             if (!fs.existsSync(dir)) fs.mkdirSync(dir)             const buffer = fs.readFileSync(chunk.path)             const ws = fs.createWriteStream(`${dir}/${hash}`)             ws.write(buffer)             ws.close()             res.send(`${filename}-${hash} Section uploaded successfully`)         } catch (error) {             console.error(error)             res.status(500).send(`${filename}-${hash} Section uploading failed`)         }     }) })  //Merged slice interface server.get('/merge', async (req, res) => {     const { filename } = req.query     try {         let len = 0         const bufferList = fs.readdirSync(`${STATIC_TEMPORARY}/${filename}`).map((hash,index) => {             const buffer = fs.readFileSync(`${STATIC_TEMPORARY}/${filename}/${index}`)             len += buffer.length             return buffer         });         //Merge files         const buffer = Buffer.concat(bufferList, len);         const ws = fs.createWriteStream(`${STATIC_FILES}/${filename}`)         ws.write(buffer);         ws.close();         res.send(`Section merge completed`);     } catch (error) {         console.error(error);     } })  server.listen(3000, _ => {     console.log('http://localhost:3000/') })

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
久久精品五月,日韩不卡视频在线观看,国产精品videossex久久发布 ,久久av综合
亚洲精品在线观看91| 国产精品对白久久久久粗| 91一区二区三区四区| 欧美1区二区| 精品一区二区三区四区五区| 精品99在线| 免费看av不卡| 欧美a级一区| 亚洲女人av| 日本成人在线一区| 国产精东传媒成人av电影| 精品成av人一区二区三区| 精品欠久久久中文字幕加勒比| 福利一区二区| 欧美一区二区三区激情视频| 99成人在线| 欧美一级网址| 精品视频自拍| 欧美 日韩 国产精品免费观看| 亚洲一区日韩| 视频小说一区二区| 日韩制服丝袜先锋影音| 久久国产三级| 欧美aa在线观看| 亚洲激情国产| 久久亚洲人体| 不卡中文字幕| 久久成人国产| 青青草视频一区| 色综合五月天| 午夜在线播放视频欧美| 欧美私人啪啪vps| 国产精品久久久久久久久妇女| 欧美色图国产精品| 亚洲精品大全| 成人台湾亚洲精品一区二区| 日韩精品一卡| 亚洲精品伊人| 国际精品欧美精品| 午夜视频精品| 国产日韩欧美一区二区三区在线观看 | 国产精品久久久久久久久久妞妞 | 中文视频一区| 国产精品99精品一区二区三区∴| 88xx成人免费观看视频库| 日韩制服丝袜先锋影音| 国产精品密蕾丝视频下载| 日韩精品一卡| 97精品资源在线观看| 久久九九国产| 国产亚洲精品精品国产亚洲综合 | 亚洲开心激情| av资源中文在线天堂| 首页亚洲欧美制服丝腿| 精品九九在线| 亚洲ww精品| 国产在线|日韩| 国产日韩中文在线中文字幕| 久久婷婷一区| 国产精品99久久久久久董美香| 136国产福利精品导航网址| 国产亚洲一区| 国产亚洲精品自拍| 麻豆一区二区99久久久久| 日韩一区二区久久| 国产在线观看91一区二区三区 | 综合激情一区| 日韩国产欧美| 国产亚洲一区二区三区啪| 婷婷成人在线| 国产精品高清一区二区| 五月天久久777| 麻豆国产精品| 亚洲精品中文字幕99999| 久久久久国产精品一区二区| 国产日韩欧美一区| 美国三级日本三级久久99 | 精品福利久久久| 日韩精品欧美大片| 黑丝一区二区三区| 国产极品一区| 日本亚洲最大的色成网站www | 国产一区二区三区四区大秀| 亚洲影院天堂中文av色| 亚洲天堂黄色| 欧美国产小视频| 91综合久久爱com| 亚洲激情国产| 日韩精品首页| 久久97视频| 日韩国产成人精品| 亚洲一区二区成人| 久久人人精品| 色乱码一区二区三区网站| 国产乱人伦精品一区| 综合激情网站| 亚洲欧美日本国产专区一区| 亚洲一级高清| 日本美女一区| 四虎成人av| 精品国产一区二区三区2021| 久久国产麻豆精品| 日韩三级精品| 亚洲三级国产| 美女网站久久| 国产精品99免费看| 婷婷激情一区| 色网在线免费观看| 精品视频国内| 你懂的国产精品| 美女性感视频久久| 国产精品激情电影| 国产精品美女在线观看直播| 欧美一区精品| 久久国产精品色av免费看| 日韩精品亚洲专区| 亚洲毛片在线免费| 日韩精品久久久久久| 日本亚洲视频在线| 中文日韩在线| 亚洲欧美日韩国产| 香蕉久久久久久久av网站| 日韩午夜av在线| 影音国产精品| 三级亚洲高清视频| 日韩三级精品| 国产精品最新| 精品国产亚洲日本| 国产精品久久久久久久久久10秀| 成人国产精品一区二区免费麻豆| 国产成人免费视频网站视频社区| 国产中文字幕一区二区三区| 不卡一二三区| 国产99精品| 日韩视频免费| 免费观看在线综合| 亚州国产精品| 国产日产高清欧美一区二区三区 | 日韩精品一区二区三区免费视频| 日韩国产欧美三级| 国产精品综合| 久久免费视频66| 亚洲风情在线资源| 免费观看不卡av| 丝袜美腿一区二区三区| 最新国产精品视频| 国产精品啊啊啊| 日韩中文欧美| 免播放器亚洲| 欧美一区影院| 黄色网一区二区| 亚州av乱码久久精品蜜桃| 亚洲精品一二三**| 韩国一区二区三区视频| 香蕉人人精品| 日韩精选在线| 国产夫妻在线| 99国产精品视频免费观看一公开 | 欧美日韩亚洲三区| 麻豆精品新av中文字幕| 亚洲一级少妇| 免费视频最近日韩| 国产精品最新| 久久一区二区三区电影| 丝袜亚洲精品中文字幕一区| 欧美专区一区| 欧美国产一级| 水蜜桃久久夜色精品一区的特点| 国产免费av一区二区三区| 日韩av免费大片| 国产视频一区在线观看一区免费| 欧美日韩一区二区三区在线电影| 亚洲黄色中文字幕| 最新国产精品| 麻豆91精品91久久久的内涵| 亚洲夜间福利| 国产精品片aa在线观看| 久久国产影院| 91精品视频一区二区| www.com.cn成人| 亚洲三区欧美一区国产二区| 色爱综合网欧美| 亚洲精品福利| 日韩不卡视频在线观看| 7m精品国产导航在线| 欧美/亚洲一区| 欧美极品一区二区三区| 99国产一区| 久久久91麻豆精品国产一区| 日韩中文视频| 国产日韩一区| 亚洲深夜av| 六月婷婷综合| 国产探花在线精品一区二区| 五月天激情综合网| 久久69成人| 亚久久调教视频| 99精品电影| 欧美a一区二区| 蜜臀国产一区二区三区在线播放|