时间:2021-07-01 10:21:17 帮助过:15人阅读
本文实例讲述了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()函数与图片上传使用
以上就是nodejs+express做出文件上传的详细内容,更多请关注Gxl网其它相关文章!