摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。方便后續(xù)文件合并。
基于Node.js的大文件分片上傳
我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如果文件過大,在網(wǎng)絡(luò)不佳的情況下,如何做到斷點續(xù)傳?也是需要記錄當(dāng)前上傳文件,然后在下一次進(jìn)行上傳請求的時候去做判斷。
先上代碼:代碼倉庫地址
前端 1. index.html2. 依賴的文件文件上傳 大文件上傳測試
自定義上傳文件
axios.js
jquery
spark-md5.js
const Koa = require("koa"); const app = new Koa(); const Router = require("koa-router"); const multer = require("koa-multer"); const serve = require("koa-static"); const path = require("path"); const fs = require("fs-extra"); const koaBody = require("koa-body"); const { mkdirsSync } = require("./utils/dir"); const uploadPath = path.join(__dirname, "uploads"); const uploadTempPath = path.join(uploadPath, "temp"); const upload = multer({ dest: uploadTempPath }); const router = new Router(); app.use(koaBody()); /** * single(fieldname) * Accept a single file with the name fieldname. The single file will be stored in req.file. */ router.post("/file/upload", upload.single("file"), async (ctx, next) => { console.log("file upload...") // 根據(jù)文件hash創(chuàng)建文件夾,把默認(rèn)上傳的文件移動當(dāng)前hash文件夾下。方便后續(xù)文件合并。 const { name, total, index, size, hash } = ctx.req.body; const chunksPath = path.join(uploadPath, hash, "/"); if(!fs.existsSync(chunksPath)) mkdirsSync(chunksPath); fs.renameSync(ctx.req.file.path, chunksPath + hash + "-" + index); ctx.status = 200; ctx.res.end("Success"); }) router.post("/file/merge_chunks", async (ctx, next) => { const { size, name, total, hash } = ctx.request.body; // 根據(jù)hash值,獲取分片文件。 // 創(chuàng)建存儲文件 // 合并 const chunksPath = path.join(uploadPath, hash, "/"); const filePath = path.join(uploadPath, name); // 讀取所有的chunks 文件名存放在數(shù)組中 const chunks = fs.readdirSync(chunksPath); // 創(chuàng)建存儲文件 fs.writeFileSync(filePath, ""); if(chunks.length !== total || chunks.length === 0) { ctx.status = 200; ctx.res.end("切片文件數(shù)量不符合"); return; } for (let i = 0; i < total; i++) { // 追加寫入到文件中 fs.appendFileSync(filePath, fs.readFileSync(chunksPath + hash + "-" +i)); // 刪除本次使用的chunk fs.unlinkSync(chunksPath + hash + "-" +i); } fs.rmdirSync(chunksPath); // 文件合并成功,可以把文件信息進(jìn)行入庫。 ctx.status = 200; ctx.res.end("合并成功"); }) app.use(router.routes()); app.use(router.allowedMethods()); app.use(serve(__dirname + "/static")); app.listen(9000);2. utils/dir.js
const path = require("path"); const fs = require("fs-extra"); const mkdirsSync = (dirname) =>?{ if(fs.existsSync(dirname))?{ return true; } else { if (mkdirsSync(path.dirname(dirname)))?{ fs.mkdirSync(dirname); return true; } } } module.exports = { mkdirsSync };操作步驟說明 服務(wù)端的搭建
我們以下的操作都是保證在已經(jīng)安裝node以及npm的前提下進(jìn)行。node的安裝以及使用可以參考官方網(wǎng)站。
新建項目文件夾file-upload
使用npm初始化一個項目:cd file-upload && npm init
安裝相關(guān)依賴
npm i koa npm i koa-router --save // Koa路由 npm i koa-multer --save // 文件上傳處理模塊 npm i koa-static --save // Koa靜態(tài)資源處理模塊 npm i fs-extra --save // 文件處理 npm i koa-body --save // 請求參數(shù)解析
創(chuàng)建項目結(jié)構(gòu)
file-upload - static - index.html - spark-md5.min.js - uploads - temp - utils - dir.js - app.js
復(fù)制相應(yīng)的代碼到指定位置即可
項目啟動:node app.js (可以使用 nodemon 來對服務(wù)進(jìn)行管理)
訪問:http://localhost:9000/index.html
其中細(xì)節(jié)部分代碼里有相應(yīng)的注釋說明,瀏覽代碼就一目了然。
后續(xù)延伸:斷點續(xù)傳、多文件多批次上傳
作者:易企秀——飯等米
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/105900.html
摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。后續(xù)延伸斷點續(xù)傳多文件多批次上傳 基于Node.js的大文件分片上傳 我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如...
摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。后續(xù)延伸斷點續(xù)傳多文件多批次上傳 基于Node.js的大文件分片上傳 我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如...
摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。后續(xù)延伸斷點續(xù)傳多文件多批次上傳 基于Node.js的大文件分片上傳 我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如...
摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。方便后續(xù)文件合并。 基于Node.js的大文件分片上傳 我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如果文件過大,在...
摘要:基于的大文件分片上傳我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。所以把文件名稱加上。方便后續(xù)文件合并。 基于Node.js的大文件分片上傳 我們在做文件上傳的時候,如果文件過大,可能會導(dǎo)致請求超時的情況。所以,在遇到需要對大文件進(jìn)行上傳的時候,就需要對文件進(jìn)行分片上傳的操作。同時如果文件過大,在...
閱讀 1667·2021-09-26 09:55
閱讀 5288·2021-09-22 15:40
閱讀 2027·2019-08-30 15:53
閱讀 1508·2019-08-30 11:15
閱讀 1725·2019-08-29 15:41
閱讀 1879·2019-08-28 18:13
閱讀 3159·2019-08-26 12:00
閱讀 1681·2019-08-26 10:30