A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

npm multer 文件上传
Express app 范本就不写了,仅记录一下上传部分的代码。
[url=][/url]
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;        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;};[url=][/url]

看到注释的那段读写文件的code了,其实multer已经把文件保存在multer_dest.dest的文件夹下面了,在同一个文件夹下,只需要rename就行了,不需要再读写了。


2 个回复

倒序浏览
有任何问题欢迎在评论区留言
回复 使用道具 举报
或者添加学姐微信
DKA-2018
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马