nodejs multer实现文件上传与下载


Posted in NodeJs onMay 10, 2017

本文实例为大家分享了nodejs实现文件上传下载的具体代码,供大家参考,具体内容如下

1.介绍

做了一个关于文件上传和下载的demo ,选择了Multer 作为中间件进行数据处理。

关于multer请参考中文翻译文档 https://github.com/expressjs/multer/blob/master/doc/README-zh-cn.md 或者官方文档

2. upload 文件上传

html form标签内设置enctype=”multipart/form-data”是必须的,这样才可以上传文件,方式为post ,在服务端使用multer时,基本与官网相同,引用中间件multer,app.post(‘\upload',upload.single(‘name'),function(){}); 指定单文件上传,参数是html的input里面的name ,这样就可以上传成功,但是问题是multer不会管你的后缀,上传到upload文件夹的文件有一个乱序名称但是没有后缀,所以我增加了这个功能。

req.file是文件信息,取得原名称,经过数组以及堆栈等处理得到后缀'.jpg' , 用fs.renameSync()方法重命名文件,加上本来的后缀。这样真正的上传成功。唯一的缺点是没有实现改变文件名字,使用官网方式出现了错误,所以没有深究。。

3.download 文件下载

网上基本上是express对res.download的封装以及fs方法为主,注意要把文件夹设定为静态文件。出现的问题是点击之后就会在新页面显示要下载的文件,无论是图片还是音乐。。这让我很困扰,但是找了很久也没有很好的解决。用IE访问结果是会出现下载还是查看的选项。。很迷。总之就是这样了,一晚上的努力,我很满足。。嘻嘻

服务端

//index.js

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

 var app = express();
 var upload = multer({dest:'upload/'});

//多文件上传 (限定上传文件个数)(没有修改后缀)
app.post('/upload-multi',upload.array('myfile',2),function(req,res,next){
  res.send("2 done");
})
//单文件上传获取信息
app.post('/upload-single',upload.single('myfile'),function(req,res,next){
  var file=req.file;
  // console.log("名称:%s",file.originalname);
  // console.log("mime:%s",file.mimetype);
//以下代码得到文件后缀
  name=file.originalname;
  nameArray=name.split('');
  var nameMime=[];
  l=nameArray.pop();
  nameMime.unshift(l);
  while(nameArray.length!=0&&l!='.'){
  l=nameArray.pop();
  nameMime.unshift(l);
  }
//Mime是文件的后缀
  Mime=nameMime.join('');
  console.log(Mime);
  res.send("done");
//重命名文件 加上文件后缀
  fs.renameSync('./upload/'+file.filename,'./upload/'+file.filename+Mime);

})

//文件下载尝试(chrome会直接在页面上展示。.最后也没有解决)
//设置download文件夹为静态 才能下载
 app.use('/download', express.static(path.join(__dirname, 'download')));
// app.get('/download',function(req,res){
//   var path='./download/aa.mp3';
//   res.download(path,'aa.mp3');
// });
app.get('/download', function(req, res){
 var file = __dirname + '/download/aa.mp3';
 res.download(file); 
});
app.get('/',function(req,res,next){
  res.sendFile(__dirname+"/index.html");
})

app.listen(3000);

客户端

//index.html

<!DOCTYPE html>
<html>
<head>
  <title>上传文件</title>
  <meta charset="utf-8">
</head>
<body>
<form enctype="multipart/form-data" action="/upload-single" method="post">
<input type="file" name="myfile"></input>
<input type="submit" value="提交"></input>
</form>

<form enctype="multipart/form-data" action="/upload-multi" method="post">
<input type="file" name="myfile"></input>
<input type="file" name="myfile"></input>
<input type="submit" value="提交"></input>
</form>
<a href="download/aa.mp3" rel="external nofollow" >下载文件</a>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
NodeJS中Buffer模块详解
Jan 07 NodeJs
NodeJS整合银联网关支付(DEMO)
Nov 09 NodeJs
详解IWinter 一个路由转控制器的 Nodejs 库
Nov 15 NodeJs
nodejs+mongodb aggregate级联查询操作示例
Mar 17 NodeJs
nodejs 十六进制字符串型数据与btye型数据相互转换
Jul 30 NodeJs
NodeJs 文件系统操作模块fs使用方法详解
Nov 26 NodeJs
用Electron写个带界面的nodejs爬虫的实现方法
Jan 29 NodeJs
通过实例了解Nodejs模块系统及require机制
Jul 16 NodeJs
Nodejs + sequelize 实现增删改查操作
Nov 07 NodeJs
nodeJs项目在阿里云的简单部署
Nov 27 NodeJs
nodejs中的异步编程知识点详解
Jan 17 NodeJs
NodeJs内存占用过高的排查实战记录
May 10 NodeJs
nodejs处理图片的中间件node-images详解
May 08 #NodeJs
使用nodejs爬取前程无忧前端技能排行
May 06 #NodeJs
win系统下nodejs环境安装配置
May 04 #NodeJs
Nodejs--post的公式详解
Apr 29 #NodeJs
NodeJs的fs读写删除移动监听
Apr 28 #NodeJs
NodeJs安装npm包一直失败的解决方法
Apr 28 #NodeJs
NodeJs模拟登陆正方教务
Apr 28 #NodeJs
You might like
php带密码功能并下载远程文件保存本地指定目录 修改加强版
2010/05/16 PHP
php学习之流程控制实现代码
2011/06/09 PHP
匹配csdn用户数据库与官方用户的重合度并将重叠部分的用户筛选出来
2011/12/25 PHP
解析PHP中VC6 X86和VC9 X86的区别及 Non Thread Safe的意思
2013/06/28 PHP
PHP register_shutdown_function()函数的使用示例
2015/06/23 PHP
php文档工具PHP Documentor安装与使用方法
2016/01/25 PHP
CI框架简单邮件发送类实例
2016/05/18 PHP
遍历jquery对象的代码分享
2011/11/02 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
2013/11/14 Javascript
JavaScript中奇葩的假值示例应用
2014/03/11 Javascript
JS onkeypress兼容性写法详解
2016/04/27 Javascript
Parcel.js + Vue 2.x 极速零配置打包体验教程
2017/12/24 Javascript
vue js秒转天数小时分钟秒的实例代码
2018/08/08 Javascript
vue router 跳转后回到顶部的实例
2018/08/31 Javascript
Vue中的$set的使用实例代码
2018/10/08 Javascript
详解Vue中组件的缓存
2019/04/20 Javascript
nodejs中request库使用HTTPS代理的方法
2019/04/30 NodeJs
python的类方法和静态方法
2014/12/13 Python
Django中的CBV和FBV示例介绍
2018/02/25 Python
Python 自动登录淘宝并保存登录信息的方法
2019/09/04 Python
使用Keras训练好的.h5模型来测试一个实例
2020/07/06 Python
python中Django文件上传方法详解
2020/08/05 Python
websocket+sockjs+stompjs详解及实例代码
2018/11/30 HTML / CSS
html5使用canvas压缩图片的示例代码
2018/09/11 HTML / CSS
英国时尚女装购物网站:Missguided
2018/08/23 全球购物
幼儿园长自我鉴定
2013/10/17 职场文书
学生打架检讨书大全
2014/01/23 职场文书
留学推荐信范文
2014/05/10 职场文书
品牌服务方案
2014/06/03 职场文书
食堂标语大全
2014/06/11 职场文书
食品工程专业求职信
2014/06/15 职场文书
2016秋季运动会前导词
2015/11/25 职场文书
2016年员工政治思想表现评语
2015/12/02 职场文书
医学生自荐信范文(2016精选篇)
2016/01/28 职场文书
Python自动化爬取天眼查数据的实现
2021/06/15 Python
Java设计模式之享元模式示例详解
2022/03/03 Java/Android