nodejs基于express实现文件上传的方法


Posted in NodeJs onMarch 19, 2018

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

前段时间在做个人项目的时候,用到了nodejs服务端上传文件,现在回头把这个小结一下,作为记录。

本人上传文件时是基于express的multiparty ,当然也可以使用connect-multiparty中间件实现,但官方似乎不推荐使用connect-multiparty中间件。废话不多说,下面看代码吧。

步骤:

(1)使用express创建项目,默认使用的是jade模板引擎,但是还是习惯于html,所以就改为html模板。
(2)在项目目录中,通过npm install multiparty进行安装必要组件。
(3)修改views/index.html,添加一个文件上传的form。

index.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>上传文件</title>
</head>
<body>
  上传文件
  <form method='post', action='/file/uploading', enctype='multipart/form-data'>
    <input type="file" name="inputFile">
    <input type="submit" value="上传">
  </form>
</body>
</html>

(4)修改routes/index.js,实现上传页面和上传响应的后台代码。

var express = require('express');
var router = express.Router();
var multiparty = require('multiparty');
var util = require('util');
var fs = require('fs');
/* 上传页面. */
router.get('/', function(req, res, next) {
 //res.render('./views/index');
 res.sendfile('./views/index.html');
});
/* 上传 */
router.post('/file/uploading', function(req, res, next) {
  /* 生成multiparty对象,并配置上传目标路径 */
  var form = new multiparty.Form();
  /* 设置编辑 */
  form.encoding = 'utf-8';
  //设置文件存储路劲
  form.uploadDir = './public/files';
  //设置文件大小限制
  form.maxFilesSize = 2 * 1024 * 1024;
  // form.maxFields = 1000;  //设置所有文件的大小总和
  //上传后处理
  form.parse(req, function(err, fields, files) {
    var filesTemp = JSON.stringify(files, null, 2);
    if(err) {
      console.log('parse error:' + err);
    }else {
      console.log('parse files:' + filesTemp);
      var inputFile = files.inputFile[0];
      var uploadedPath = inputFile.path;
      var dstPath = './public/files' + inputFile.originalFilename;
      //重命名为真实文件名
      fs.rename(uploadedPath, dstPath, function(err) {
        if(err) {
          console.log('rename error:' + err);
        }else {
          console.log('rename ok');
        }
      })
    }
    res.writeHead(200, {'content-type': 'text/plain;charset=utf-8'});
    res.write('received upload:\n\n');
    res.end(util.inspect({fields: fields, files: filesTemp}))
  })
})
module.exports = router;

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

NodeJs 相关文章推荐
nodejs教程之制作一个简单的文章发布系统
Nov 21 NodeJs
NodeJS与HTML5相结合实现拖拽多个文件上传到服务器的实现方法
Jul 26 NodeJs
Nodejs多站点切换Htpps协议详解及简单实例
Feb 23 NodeJs
Nodejs中使用captchapng模块生成图片验证码
May 18 NodeJs
NodeJs form-data格式传输文件的方法
Dec 13 NodeJs
nodejs实现连接mongodb数据库的方法示例
Mar 15 NodeJs
原生nodejs使用websocket代码分享
Apr 07 NodeJs
Nodejs实现多文件夹文件同步
Oct 17 NodeJs
nodejs二进制与Buffer的介绍与使用
Jul 11 NodeJs
Nodejs libuv运行原理详解
Aug 21 NodeJs
nodejs+koa2 实现模仿springMVC框架
Oct 21 NodeJs
分享node.js实现简单登录注册的具体代码
Apr 26 NodeJs
nodejs+mongodb aggregate级联查询操作示例
Mar 17 #NodeJs
nodejs实现超简单生成二维码的方法
Mar 17 #NodeJs
NodeJS父进程与子进程资源共享原理与实现方法
Mar 16 #NodeJs
NodeJS实现不可逆加密与密码密文保存的方法
Mar 16 #NodeJs
nodejs简单读写excel内容的方法示例
Mar 16 #NodeJs
nodejs简单访问及操作mysql数据库的方法示例
Mar 15 #NodeJs
nodejs实现的简单web服务器功能示例
Mar 15 #NodeJs
You might like
php与mysql建立连接并执行SQL语句的代码
2011/07/04 PHP
php curl选项列表(超详细)
2013/07/01 PHP
彻底删除thinkphp3.1案例blog标签的方法
2014/12/05 PHP
微信支付PHP SDK之微信公众号支付代码详解
2015/12/09 PHP
PHP数组操作实例分析【添加,删除,计算,反转,排序,查找等】
2016/12/24 PHP
javascript 鼠标滚轮事件
2009/04/09 Javascript
善用事件代理,警惕闭包的性能陷阱。
2011/01/20 Javascript
使用js检测浏览器的实现代码
2013/05/14 Javascript
jquery中插件实现自动添加用户的具体代码
2013/11/15 Javascript
一个可以增加和删除行的table并可编辑表格中内容
2014/06/16 Javascript
javascript控制层显示或隐藏的方法
2015/07/22 Javascript
jQuery操作复选框(CheckBox)的取值赋值实现代码
2017/01/10 Javascript
Vue.js 使用v-cloak后仍显示变量的解决方法
2018/11/19 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
jQuery 实现扁平式小清新导航
2020/07/07 jQuery
python使用rsa加密算法模块模拟新浪微博登录
2014/01/22 Python
python的类方法和静态方法
2014/12/13 Python
解决python3 安装完Pycurl在import pycurl时报错的问题
2018/10/15 Python
Django配置MySQL数据库的完整步骤
2019/09/07 Python
解决Python3下map函数的显示问题
2019/12/04 Python
Python使用enumerate获取迭代元素下标
2020/02/03 Python
pytorch实现Tensor变量之间的转换
2020/02/17 Python
python 弧度与角度互转实例
2020/04/15 Python
windows+vscode安装paddleOCR运行环境的步骤
2020/11/11 Python
彻底弄明白CSS3的Media Queries(跨平台设计)
2010/07/27 HTML / CSS
巴西香水和化妆品购物网站:The Beauty Box
2019/09/03 全球购物
网络方面基础面试题
2012/11/16 面试题
北京麒麟网信息技术有限公司网络游戏测试面试题
2013/09/28 面试题
财务部岗位职责
2013/11/19 职场文书
家具厂厂长岗位职责
2014/01/01 职场文书
七一讲话心得体会
2014/09/05 职场文书
写给医生的感谢信
2015/01/22 职场文书
网吧温馨提示
2015/07/17 职场文书
八年级作文之感悟亲情
2019/11/20 职场文书
Python进行区间取值案例讲解
2021/08/02 Python
《现实主义勇者的王国再建记》第三弹OST全曲试听片段公开
2022/04/04 日漫