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.