最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

nodejs基于express实现文件上传

来源:动视网 责编:小采 时间:2020-11-27 19:58:51
文档

nodejs基于express实现文件上传

nodejs基于express实现文件上传:本文主要和大家介绍了nodejs基于express实现文件上传的方法,结合实例形式分析了nodejs基于express框架实现文件上传功能的具体步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。本人上传文件时是基于express的multiparty ,当然也可以
推荐度:
导读nodejs基于express实现文件上传:本文主要和大家介绍了nodejs基于express实现文件上传的方法,结合实例形式分析了nodejs基于express框架实现文件上传功能的具体步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。本人上传文件时是基于express的multiparty ,当然也可以


本文主要和大家介绍了nodejs基于express实现文件上传的方法,结合实例形式分析了nodejs基于express框架实现文件上传功能的具体步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。

本人上传文件时是基于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基于express实现文件上传

nodejs基于express实现文件上传:本文主要和大家介绍了nodejs基于express实现文件上传的方法,结合实例形式分析了nodejs基于express框架实现文件上传功能的具体步骤与相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。本人上传文件时是基于express的multiparty ,当然也可以
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top