您的当前位置:首页正文

nodejs+express做出文件上传

2020-11-27 来源:意榕旅游网

这次给大家带来nodejs+express做出文件上传,nodejs+express做出文件上传的注意事项有哪些,下面就是实战案例,一起来看一下。

本文实例讲述了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;

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

ip无法访问vue+webpack+myproject项目如何处理

vue-cli+webpack无法新建项目

preload()函数与图片上传使用

显示全文