简体   繁体   中英

Express send passport to app.use(route)

I am trying to send passport to app.use('/api')(passport) but I seem to get an error when doing so. Should I even send it to app.use() or can I just recuire() it in profile.js file? I am new to express and was following a tutorial on how to implement passport.js .

F:\App\node_modules\express\lib\router\index.js:140
  var search = 1 + req.url.indexOf('?');
                          ^
TypeError: Cannot read property 'indexOf' of undefined
    at Function.handle (F:\App\node_modules\express\lib\router\index.js:140:27)
    at EventEmitter.handle (F:\App\node_modules\express\lib\application.js:173:10)
    at app (F:\App\node_modules\express\lib\express.js:38:9)
    at ExpressRouter (F:\App\app\backend\router\routes.js:15:31)
    at Object.<anonymous> (F:\App\app\backend\backend.app.js:36:27)
    at Module._compile (module.js:541:32)
    at Object.Module._extensions..js (module.js:550:10)
    at Module.load (module.js:458:32)
    at tryModuleLoad (module.js:417:12)
    at Function.Module._load (module.js:409:3)
    at Module.require (module.js:468:17)
    at require (internal/module.js:20:19)
    at Object.<anonymous> (F:\App\app\server.js:8:11)
    at Module._compile (module.js:541:32)
    at Object.Module._extensions..js (module.js:550:10)
    at Module.load (module.js:458:32)

Server.js

var config = require('./config/config');
var logger = require('morgan');
var path = require('path');
var express = require('express');
var app = require('./backend/backend.app.js');
app.use(logger('dev'));
app.use(express.static('../'));
app.use(express.static(path.join(__dirname, './frontend')));
app.all('/*', function (req, res) {
    res.sendFile(path.join(__dirname, './frontend/index.html'));
});

backend.app.js

var express = require('express');
var app = express();
var passport = require('passport');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var session = require('express-session');
var config = require('../config/config');
var flash = require('connect-flash');
require('./models/user');
require('./lib/passport')(passport);
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended:true}));
app.use(cookieParser());
app.use(session({ secret: 'secret',resave: true, saveUninitialized: true  }));
app.use(passport.initialize());
app.use(passport.session());
app.use(flash());
require('./router/routes')(app, passport);
module.exports = app;

routes.js

var profile = require('./routes/profile');
var isLoggedIn = function(req, res, next){
    if(req.isAuthenticated())
        return next();
    res.redirect('/');
};
var ExpressRouter = function(app, passport){
    app.use('/api', profile)(passport);
};
module.exports = ExpressRouter;

profile.js

var express = require('express');
var router = express.Router();
var mongoose = require('mongoose');
var User = mongoose.model('User');

module.exports = function (passport){
    router.post('/signup', passport.authenticate('local-signup', {
        successRedirect : '/',
        failureRedirect : '/signup',
        failureFlash : true
    }));
    return router;
};

In your case, you must call app.use with a router object as the second argument. So, instead of

app.use('/api', profile)(passport);

You should write it like this in your routes.js file:

app.use('/api', profile(passport));

Since profile(passport) return an express router object.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM