Node.js + express实现上传大文件的方法分析【图片、文本文件】


Posted in Javascript onMarch 14, 2019

本文实例讲述了Node.js + express实现上传大文件的方法。分享给大家供大家参考,具体如下:

对于大文件的上传我们首先要引入一个叫做 multer 的库:

npm install --save multer

关于这个库,大家可以查阅官方文档:

点击跳转 https://www.npmjs.com/package/multer

我们先将库引入我们的项目中:

var multer = require('multer')
var upload = multer({ dest: 'uploads/' })// 文件会上传到这个目录

具体的 get 方法:

app.post('/upload', upload.single('logo'), function(req, res){//发送 json 数据到这个路由
  console.dir(req.file);
  res.send(req.p);
})

由于上传文件要用到表当,所以我们这里先建立一个名为 form 表单:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
  <form action="/upload" method="post" enctype="multipart/form-data">
    <h2>单图上传</h2>
    <input type="file" name="logo">
    <input type="submit" value="提交">
  </form>
<body>
</body>
</html>

然后我们在 server 中引入该表单:

var fs = require('fs')
// /from 的 html 界面,用于演示上传文件
app.get('/form',function(req, res){
  var form = fs.readFileSync('./form.html',{ encoding : "utf8"});
  res.send(form);
})

由 localhost:3000/form 运行后上传文件,就能在你项目的upload目录下可看到:

Node.js + express实现上传大文件的方法分析【图片、文本文件】

Node.js + express实现上传大文件的方法分析【图片、文本文件】

虽然上传成功,但w我n看到文件名是混乱的,而且路径也是固定:

修改路径和文件名:

// 更改大文件的存储路径
var createFolder = function(folder){
  try{
    fs.accessSync(folder);
  }catch( e ){
    fs.mkdirSync(folder);
  }
};
var uploadFolder = './upload/';// 设定存储文件夹为当前目录下的 /upload 文件夹
createFolder(uploadFolder);
// 磁盘存贮
var storage = multer.diskStorage({
  destination: function (req, file, cb) {
    cb(null, uploadFolder );// 他会放在当前目录下的 /upload 文件夹下(没有该文件夹,就新建一个)
  },
  filename: function (req, file, cb) {// 在这里设定文件名
    cb(null, file.originalname );
  }
})
var upload = multer({ storage: storage })

效果:

Node.js + express实现上传大文件的方法分析【图片、文本文件】

最后,这里是视屏连接方便大家学习:

https://www.bilibili.com/video/av24385038/?p=6

希望本文所述对大家nodejs程序设计有所帮助。

Javascript 相关文章推荐
JS将数字转换成三位逗号分隔的样式(示例代码)
Feb 19 Javascript
JavaScript中使用Object.prototype.toString判断是否为数组
Apr 01 Javascript
实现前后端数据交互方法汇总
Apr 07 Javascript
js鼠标点击图片切换效果代码分享
Aug 26 Javascript
JS实现图片局部放大或缩小的方法
Aug 20 Javascript
vue.js指令v-for使用及索引获取
Nov 03 Javascript
vue 2.0路由之路由嵌套示例详解
May 08 Javascript
Vue编写多地区选择组件
Aug 21 Javascript
JavaScript框架Angular和React深度对比
Nov 20 Javascript
小程序实现列表多个批量倒计时
Jan 29 Javascript
微信小程序页面传多个参数跳转页面的实现方法
May 17 Javascript
kafka调试中遇到Connection to node -1 could not be established. Broker may not be available.
Sep 17 Javascript
React+Antd+Redux实现待办事件的方法
Mar 14 #Javascript
Node.js + express基本用法教程
Mar 14 #Javascript
Vue渲染过程浅析
Mar 14 #Javascript
详解关于JSON.parse()和JSON.stringify()的性能小测试
Mar 14 #Javascript
详解使用React制作一个模态框
Mar 14 #Javascript
JavaScript碎片—函数闭包(模拟面向对象)
Mar 13 #Javascript
详解js动态获取浏览器或页面等容器的宽高
Mar 13 #Javascript
You might like
《OVERLORD》手游英文版即将上线 手机上也能扮演骨王
2020/04/09 日漫
基于HTTP长连接的&quot;服务器推&quot;技术的php 简易聊天室
2009/10/31 PHP
33道php常见面试题及答案
2015/07/06 PHP
php根据年月获取当月天数及日期数组的方法
2016/11/30 PHP
php常用的工具开发整理
2019/09/26 PHP
浅谈Laravel POST,PUT,PATCH 路由的区别
2019/10/15 PHP
javascript实现可改变滚动方向的无缝滚动实例
2013/06/17 Javascript
javascript的渐进增强与平稳退化浅谈
2013/11/12 Javascript
js实现可拖动DIV的方法
2013/12/17 Javascript
jquery单行文字向上滚动效果示例
2014/03/06 Javascript
jQuery CSS()方法改变现有的CSS样式
2014/08/20 Javascript
解决jquery无法找到其他父级子集问题的方法
2016/05/10 Javascript
15位和18位身份证JS校验的简单实例
2016/07/18 Javascript
javascript实现延时显示提示框效果
2017/06/01 Javascript
angular实现图片懒加载实例代码
2017/06/08 Javascript
详解Javascript 中的 class、构造函数、工厂函数
2017/12/20 Javascript
node下使用UglifyJS压缩合并JS文件的方法
2018/03/07 Javascript
Vue的路由动态重定向和导航守卫实例
2018/03/17 Javascript
解决angularjs中同步执行http请求的方法
2018/08/13 Javascript
详解如何用VUE写一个多用模态框组件模版
2018/09/27 Javascript
微信小程序之裁剪图片成圆形的实现代码
2018/10/11 Javascript
[00:02]DOTA2新版本使用PA至宝后暴击展示
2014/11/19 DOTA
python网络编程之读取网站根目录实例
2014/09/30 Python
Windows和Linux下使用Python访问SqlServer的方法介绍
2015/03/10 Python
python实现简单的socket server实例
2015/04/29 Python
python处理xml文件的方法小结
2017/05/02 Python
使用pyecharts在jupyter notebook上绘图
2020/04/23 Python
Django 根据数据模型models创建数据表的实例
2018/05/27 Python
Python判断telnet通不通的实例
2019/01/26 Python
python爬虫增加访问量的方法
2019/08/22 Python
Python实现将蓝底照片转化为白底照片功能完整实例
2019/12/13 Python
Python检测端口IP字符串是否合法
2020/06/05 Python
python 中 .py文件 转 .pyd文件的操作
2021/03/04 Python
英国轻奢珠宝品牌:Astley Clarke
2016/12/18 全球购物
个人安全生产责任书
2014/07/28 职场文书
vue组件冲突之引用另一个组件出现组件不显示的问题
2022/04/13 Vue.js