文件上传返回“未定义”

时间:2020-07-17 20:19:09

标签: javascript node.js express

因此,我正在使用 Express File Upload ,当我尝试向其发送发布请求时,它从设置的错误处理程序中返回错误,这实际上是找不到的我console.log(req.files)返回的所有文件都未定义,这就是为什么该错误被发送回去的原因,但是我不知道如何解决该问题。

Index.js

router.post('/upload-avatar', async (req, res) => {
  try {
    console.log(req.files)
    if(!req.files) {
      res.send({
        status: false,
        message: 'No file uploaded'
      });
    } else {
      //Use the name of the input field (i.e. "avatar") to retrieve the uploaded file
      let avatar = req.files.avatar;

      //Use the mv() method to place the file in upload directory (i.e. "uploads")
      avatar.mv('./uploads/' + avatar.name);

      //send response
      res.send({
        status: true,
        message: 'File is uploaded',
        data: {
          name: avatar.name,
          mimetype: avatar.mimetype,
          size: avatar.size
        }
      });
    }
  } catch (err) {
    res.status(500).send(err);
  }
});

App.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');


const fileUpload = require('express-fileupload');
const cors = require('cors');
const bodyParser = require('body-parser');
const _ = require('lodash');

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);
app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});



app.use(fileUpload({
  createParentPath: true
}));
app.use(cors());
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));


// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

我正在使用azure服务器,目前正在使用邮递员使其首先工作!

预先感谢!

1 个答案:

答案 0 :(得分:0)

中间件应适当订购。您的文件上传中间件位于索引路由器的下方。因此,当请求到达服务器时,Express会在上载中间件之前运行indexRouter的处理程序,并且除非您的处理程序调用{​​{1}},否则文件上载中间件将不会处理您的请求。而且您无法致电next(),因为这意味着“我已经完成了我的工作,将请求(请求)交给下一个中间件/处理程序”。

next()