文件上传的简单使用

2019-10-21  本文已影响0人  散樱乱舞
//文件上传测试
const express = require('express');
const router = express.Router();

const fs = require('fs');
const multer = require('multer');
let path = require("path");

function uploadConfig(folder, mb, suffix) {
    // folder:上传文件的具体分类(具体文件夹名字)
    // mb:上传文件的大小限制(KB)
    // suffix:上传文件的类型控制(数组)
    path_new = path.resolve(__dirname, '../public/uploads/' + folder);
    return multer({
        storage: multer.diskStorage({
            //文件存储位置  
            destination: (req, file, cb) => {
                fs.mkdir(path_new, { recursive: true }, (err) => {
                    if (err) throw err;
                });
                cb(null, path_new);
            },
            //文件名  
            filename: (req, file, cb) => {
                cb(null, `${Date.now()}_${Math.ceil(Math.random() * 1000)}_multer.${file.originalname.split('.').pop()}`);
            }
        }),
        limits: {
            //上传文件的大小限制,单位bytes  
            fileSize: 1024 * 1024 * mb
        },
        fileFilter: (req, file, cb) => {
            //文件类型
            if (suffix.indexOf(file.mimetype) !== -1) {
                cb(null, true);
            } else {
                cb(null, false);
            }
        }
    }).any();
}

router.post('/upload/img', uploadConfig('images/', 10, ['image/jpeg', 'image/jpg']), async function (req, res, next) {
    let uploadFile = req.files;
    if (uploadFile.length == 0) {
        res.json({ code: 233, info: '文件上传错误' });
    } else {
        res.json({ code: 200, info: `文件上传成功数量:${uploadFile.length}`, mes: uploadFile });
    }
});

module.exports = router;
上一篇 下一篇

猜你喜欢

热点阅读