Express multer 文件上传
时间:2019-10-14
本文章向大家介绍Express multer 文件上传,主要包括Express multer 文件上传使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
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就行了,不需要再读写了。
原文地址:https://www.cnblogs.com/view85/p/11671976.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 群组复制MySQL Group Replication
- 关于自定义单选框InfoPreference的笔记
- Python爬虫之gerapy爬虫管理
- 内存地址中藏着的学问
- Python爬虫之crawlspider类的使用
- 数据结构 - 堆(Heap)
- 信息收集之主机发现:masscan
- 信息收集之社工字典
- CloudBase CMS 2.0 焕新升级,从「心」出发!
- 使用MySQL Keyring 的 SECRET类型密钥执行非对称加密
- node egg 实现跨域
- 使用Markdown画流程图
- HBase NotServingRegionException
- Flink SQL 写入 Hive表的性能问题
- 文件系统索引extent 和 bitmap区别