wake-up-neo.net

typerror: app.use () erfordert eine Middleware-Funktion

Ich lerne node.js mit der Express-Template-Engine. Ich folge dem udemy-Kurs "learn node.js durch das Erstellen von 10 Projekten" und folge einer Vorlesung, wenn der Professor npm start localhost:3000 läuft, während mein Fehler erscheint, der angibt, dass app.use eine Middleware-Funktion erfordert Ich habe übereinstimmenden Code ausprobiert. Bitte helfen Sie mir, den Fehler zu beheben, den ich seit Stunden hier feststeckte. Ich habe viele Änderungen vorgenommen, aber es funktioniert nicht für mich.

Wenn ich versuche, 'npm start' auszuführen, erscheint der folgende Fehler.

TypeError: app.use () erfordert Middleware-Funktionen

Hier ist der Code von app.js:

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var expressValidator = require('express-validator');
var cookieParser = require('cookie-parser');
var session = require('express-session');
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var bodyParser = require('body-parser');
var multer = require('multer');
var flash = require('connect-flash');
var mongo = require('mongodb');
var mongoose = require('mongoose');
var db = mongoose.connection;

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

var app = express();

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

//Handle File Uploads
app.use(multer({
  dest: './uploads'
}));

// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
  extended: false
}));

//Handle Express Sessions
app.use(session({
  secret: 'secret',
  saveUninitialied: true,
  resave: true
}));

//Passport
app.use(passport.initialize());
app.use(passport.session());

//Validator
app.use(expressValidator({
  errorFormatter: function(param, msg, value) {
    var namespace = param.split('.'),
      root = namespace.shift(),
      formParam = root;

    while (namespace.length) {
      formParam += '[' + namespace.shift() + ']';
    }
    return {
      param: formParam,
      msg: msg,
      value: value
    };
  }
}));

app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use(flash());

app.use(function(req, res, next) {
  res.locals.messages = require('express-messages')(req, res);
  next();
});

app.use('/', routes);
app.use('/users', users);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});



module.exports = app;

Hier ist package.json Datei

{
  "name": "nodeauth",
  "version": "1.0.0",
  "private": true,
  "scripts": {
    "start": "node ./bin/www"
  },
  "dependencies": {
    "body-parser": "~1.12.4",
    "cookie-parser": "~1.3.5",
    "debug": "~2.2.0",
    "express": "~4.12.4",
    "jade": "~1.9.2",
    "morgan": "~1.5.3",
    "serve-favicon": "~2.2.1",
    "mongodb": "*",
    "mongoose": "*",
    "connect-flash": "*",
    "express-validator": "*",
    "express-session": "*",
    "express-messages": "*",
    "passport": "*",
    "passport-local": "*",
    "passport-http": "*",
    "multer": "*"
  }
}

Hier ist app.js aktualisiert (nach dem Entfernen von Multar)

var express          = require('express'),
    path             = require('path'),
    favicon          = require('serve-favicon'),
    logger           = require('morgan'),
    cookieParser     = require('cookie-parser'),
    expressValidator = require('express-validator'),
    session          = require('express-session'),
    passport         = require('passport'),
    LocalStrategy    = require('passport-local').Strategy,
    bodyParser       = require('body-parser'),
    flash            = require('connect-flash'),
    mongo            = require('mongodb'),
    mongoose         = require('mongoose'),

    db = mongoose.connection,

    routes = require('./routes/index'),
    users  = require('./routes/users'),

    app = express();

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

// handle file uploads

//multer delted


// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));

// handle express sessions
app.use(session({
  secret: 'keyboard cat',
  resave: true,
  saveUninitialized: true
}));

// passport
app.use(passport.initialize());
app.use(passport.session());

// validator
app.use(expressValidator({
  errorFormatter: function(param, msg, value) {
    var namespace = param.split('.'),
        root      = namespace.shift(),
        formParam = root;

    while(namespace.length) {
      formParam += '[' + namespace.shift() + ']';
    }

    return {
      param: formParam,
      msg  : msg,
      value: value
    };
  }
}));

app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

// flash
app.use(flash());

// express messages
app.use(function(req, res, next) {
  res.locals.messages = require('express-messages')(req, res);
  next();
});

app.get('*', function(req, res, next) {
  res.locals.user = req.user || null;
  next();
});

app.use('/', routes);
app.use('/users', users);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


//Express server
var http = require('http');
var server = http.createServer(app);

app.get('/', function(req, res) {
    res.send("Hello World!");
});

server.listen(3000, 'localhost');
server.on('listening', function() {
    console.log('Express server started on port %s at %s', server.address().port, server.address().address);
});

module.exports = app;

Danke dir

29
mean learner

Es hat auf diese Weise funktioniert. lösche diese Zeile,

app.use(multer({ dest: './uploads' }));

und benutze es als

var multer = require('multer');
var upload = multer({ dest: './uploads' });

Ich folge auch demselben Kurs

54

Veränderung: 

//Handle File Uploads
app.use(multer({
  dest: './uploads'
}));

Für so etwas wie:

app.use(multer({dest:'./uploads/'}).single('singleInputFileName'));

oder

app.use(multer({dest:'./uploads/'}).array('multiInputFileName'));

Und achten Sie darauf, etwas zu haben:

<form action="/postPhotos" enctype="multipart/form-data">
    <input type="file" name="singleInputFileName">
    <input type="submit" value="Upload photo">
</form>

für den ersten Fall oder:

<form action="/postPhotos" enctype="multipart/form-data">
    <input type="file" name="multiInputFileName" multiple>
    <input type="submit" value="Upload photo">
</form>

Für die zweite in Ihrer HTML.

24
Rubén Marrero

Das hat bei mir funktioniert:

app.use(multer({
  dest: path.join(__dirname, 'public/upload/temp')
}).any());

Ich habe diesen Kurs auch gemacht und bin auf das gleiche Problem gestoßen. Ich habe den Fehler behoben, indem ich die Multer-Gebrauchsanweisungen von ihrem Github befolgte: https://github.com/expressjs/multer

Hier ist der Code aus ihrer README:

    var multer  = require('multer')
    var upload = multer({ dest: 'uploads/' })

Hier ist der Code, den ich verwendet habe, um den Fehler zu überwinden, während er dieses Tutorial durchführte:

    var multer = require('multer');
    var upload = multer({ dest: './uploads' });

Ich hoffe es hilft :)

6
MikeLee

sie können einfach verwenden:

app.set(multer({dest: "./uploads"}));

es funktioniert auch für mich.

2
Ashraf

Ändern Sie nur diese Zeile

app.use(multer({dest:'./uploads'}));

zu 

var upload =multer({dest:'./uploads'});
0
Edwin Ikechukwu

app.use(multer({dest:'./uploads'})); ersetzen 

zu

var upload = multer({dest:'./uploads'});

arbeitete für mich.

0
marwari