前段时间在做个人项目的时候,用到了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实现文件上传相关推荐

  1. nodejs+multiparty 文件上传

    通过表单提交上传文件:     html代码 <form action="/uploadFile" method="post" enctype=" ...

  2. nodeJs实现文件上传,下载,删除

    转:https://blog.csdn.net/qq_36228442/article/details/81709272 一.简介 本文介绍了nodeJs+express框架下,用multer中间件实 ...

  3. nodejs multiparty 文件上传

    var multiparty = require('multiparty'); function fileUpload(req,res)     {         //生成multiparty对象, ...

  4. nodejs文件服务器断点续传,基于Nodejs的大文件上传之断点续传

    接着<扒一扒Nodejs formidable的onPart>和<也说文件上传之兼容IE789的进度条---丢掉flash>:前面已完成兼容IE789的大文件上传:无flash ...

  5. axios nodejs 上传图片_Vue Axios跨域、文件上传

    本文以vue-cli中使用axios为例 安装 npm install --save axios 引用(注册到VUE实例中) import Vue from 'vue' import Axios fr ...

  6. nodejs ajax进度条,Ajax异步文件上传与NodeJS express服务端处理的示例分析

    Ajax异步文件上传与NodeJS express服务端处理的示例分析 发布时间:2021-07-24 11:17:21 来源:亿速云 阅读:79 作者:小新 这篇文章主要介绍Ajax异步文件上传与N ...

  7. 【转】NodeJS教程--基于ExpressJS框架的文件上传

    本文是翻译的一篇文章,原文地址:Handle File Uploads in Express (Node.js). 在NodeJS发展早期上传文件是一个较难操作的功能,随后出现了formidable. ...

  8. Html5+NodeJS——拖拽多个文件上传到服务器

    实现多文件拖拽上传的简易Node项目,可以在github上下载,你可以先下载下来:https://github.com/Johnharvy/upLoadFiles/. 解开下载下的zip格式包,建议用 ...

  9. Nodejs基于express+multer的文件上传

    概览 图片上传是web开发中经常用到的功能,node社区在这方面也有了相对完善的支持. 常用的开源组件有multer.formidable等,借助这两个开源组件,可以轻松搞定图片上传. 本文主要讲解以 ...

最新文章

  1. 解决myeclipse中新建javaweb工程,无法使用Web App Libraries问题
  2. linux shell 删除两个文件相同部分
  3. iBatis 的插入一个实体
  4. 单调队列 Monotonic Queue / 单调栈 Monotonic Stack
  5. kryo java_优化Java序列化– Java,XML,JSON,Kryo,POF
  6. numpy将ndarray数据拼接合并
  7. elementUi源码解析(1)--项目结构篇
  8. 【报告分享】2020年中国金融科技企业领袖观点洞察报告.pdf(附下载链接)
  9. 英伟达的“千人摩擦计划”:几千个智能体互相玩耍,学习跑酷更轻松
  10. mysql 5.7 延迟同步_完全解决 MySQL 5.7 主从复制的延迟问题
  11. 交返对于高频交易者尤为重要
  12. 全世界最高级最好的操作系统,人人都可以用
  13. copypng emitted errors
  14. Stata学习手册——第一讲
  15. python中各种属性与方法深析
  16. matlab通过数据进行曲线拟合 导出公式
  17. 计算机联锁验证实训报告心得,计算机实训心得体会(通用5篇)
  18. 什么是restful?说说你对restful的理解
  19. Android数据传输加密(一):Base64转码算法
  20. Rational_Rose破解安装

热门文章

  1. java mqtt客户端_基于 t-io 实现一个 mqtt5 协议之 mica-mqtt
  2. gorm preload 搜索_文件太多忘记了文件放在什么地方?那你可以试试这款文件搜索工具...
  3. Redis在windows下安装过程(转载)
  4. bzoj1128 Lam-lights
  5. Date扩展 正则匹配
  6. Codeforces Beta Round #17 C. Balance DP
  7. EntityFramework 插件之EntityFramework.Extended (批量处理)
  8. 板邓:wordpress自定义登录页面实现用户登录
  9. KAFKA分布式消息系统
  10. 验证dropdownlist必选