Express multer 文件上傳

来源:https://www.cnblogs.com/view85/archive/2019/10/14/11671976.html

npm multer 文件上傳 Express app 範本就不寫了,僅記錄一下上傳部分的代碼。 const fs = require('fs'); const express = require('express'); const multer = require('multer'); const ...


npm multer 文件上傳

Express app 範本就不寫了,僅記錄一下上傳部分的代碼。

const fs = require('fs');
const express = require('express');
const multer  = require('multer');

const multer_dest = multer({dest: 'public/uploads/'});


const async_route_wrap = fn => {
    return function wrap(...args) {
        const ret = fn(...args);
        const next = args[args.length - 1];
        return Promise.resolve(ret).catch(next);
    };
};


const index = async(req, res) => {

    res.send(`<form method="post" action="/upload" enctype="multipart/form-data">
            <input type="file" name="file1"/>
            <button type="submit">upload</button>
            </form`);
};


const upload = async(req, res) => {

    if (!req.files) return res.json({status: 'failed.'});

    const count = req.files.length;
    for (let i = 0; i < count; i++) {

        const {originalname, size, path: upload_path} = req.files[i];
        const save_path = `./public/uploads/${originalname}`;


        console.log(`Name: ${originalname}, Size: ${size}`);

        fs.renameSync(upload_path, save_path);

        /*
        fs.readFile(file_path, (err, data) => {
            fs.writeFile(new_path, data, (err) => {
                if (err) {
                    console.error(err);
                    throw err;
                } else {
                    if (i + 1 === count) {
                        res.json({status: 'success'});
                    }
                }                
            });
        });
        */
    }

    res.json({
        status: 'success'
    });
};


module.exports = () => {
    const router = express.Router();

    router.get('/', async_route_wrap(index));
    router.post('/upload', multer_dest.any(), async_route_wrap(upload));

    return router;
};

看到註釋的那段讀寫文件的code了,其實multer已經把文件保存在multer_dest.dest的文件夾下麵了,在同一個文件夾下,只需要rename就行了,不需要再讀寫了。


您的分享是我們最大的動力!

更多相關文章
  • webpack 插件 ProvidePlugin:自動載入模塊,而不必到處 import 或 require 。 ...
  • 一.a標簽完成 二.js實現下載 三.js中ajax實現音頻或者視頻不跳轉進行文件下載 寫代碼的思路 四.fetch實現 ...
  • 參考自網站:https://segmentfault.com/a/1190000011779959 插件安裝完成之後,還要對一些插件進行配置,例如: vetur預設配置, 配置的過程: 打開 文件 > 首選項 > 用戶設置(U) > 點擊右上角 打開設置(json) // 執行文字相關的導航或操作時 ...
  • 本資源是我在源代碼網站上發現的,內附幾十種背景動態特效,我單獨提取出來精品背景特效在此分享,文件里有20多種精品動態效果,本人覺得可用作於個人博客主頁背景,登陸頁面背景等,有20多個背景特效,非常漂亮。 附文件下載地址: https://github.com/chengpu2/web2 ...
  • 文件/大文件上傳功能實現(JS+PHP) 參考博文:掘金-橙紅年代 前端大文件上傳 路漫漫 其修遠 PHP + JS 實現大文件分割上傳 本文是學習文件上傳後的學習總結文章,從無到有實現文件上傳功能,前端小白寫的代碼不是最優,如果有錯誤的地方請多多指教,如果本文對你有所幫助,深感榮幸。 近期公司的項 ...
一周排行
  • 場景 在Winfom中可以在頁面上多個按鈕或者右鍵的點擊事件中觸發同一個自定義的委托事件。 實現 在位置一按鈕點擊事件中觸發 string parentPath = System.IO.Directory.GetParent("指定路徑").ToString(); //獲取指定路徑的父級目錄並作為參 ...
  • asp.net 根據html模板導出excel public class ExcelHelper { /// <summary> /// 根據html模板文件生成excel文件 /// </summary> /// <param name="ds">數據源</param> /// <param na ...
  • asp.net 使用NPOI讀取excel文件內容 NPOI下載地址:NPOI public class ExcelHelper { /// <summary> /// 讀取Excel文件數據到DataSet,一個Sheet對應一個DataTable /// </summary> /// <para ...
  • 場景 使用Visual Studio 開發Winform程式,使用SVN進行項目版本管理。 在添加引用時,會出現在A電腦中添加了絕對路徑的引用,在B電腦中就會出現找不到 並且將此引用標識為?的狀態。 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi ...
  • asp.net 使用 Application 限制單一登錄 原理:用戶登錄後系統會分配一個與用戶唯一對應的SessionID,將當前用戶ID與其SessionID對應保存在Application中,一旦該用戶在其他地方重覆登錄則Application中保存的SessionID就會被更新,導致當前se ...
  • 當我們的系統時間不正常,比如設置一個日期-1999年9月9日,會引發證書問題。 系統時間不正常-IE有概率能訪問 觸發NavigateError事件,異常代碼INET_E_INVALID_CERTIFICATE -- 這是一個必要不充分條件,系統時間不正常時IE有相關證書異常,更新時間能解決此類異常 ...
  • //加密 public static string GDEncode(string data, string Key) { Key = "12345678"; byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(Key); byte[] b ...
  • static void CopyFiles() { string sourceDir = @"D:\C\ll"; string destDir = @"D:\LL"; if (!Directory.Exists(destDir)) { Directo... ...
  • //接收的為空時,則表示客戶端下線,跳出迴圈 if (r == 0) { break; }; string str = Encoding.UTF8.GetString(buffer, 0, r); //RemoteEndPoint:可以得到遠程客戶端的IP和埠號。 ShowMsg(socketSe... ...
  • 本文梯子 前言 1、.net core 框架性能測試 2、.net core 執行過程 3、中間件執行過程 4、AOP切麵 5、整體框架結構與資料庫表UML 一、創建第一個Core 1、SDK 安裝 2、新建項目 2、新建項目(3.0SDK) 3、項目整體結構分析 二、重要文件說明 1、Progra ...
x