Nœud jette TypeError: Cannot read property 'indexOf' undefined

Pas certain, mais je pense avoir quelque chose qui DEVRAIT fonctionner, mais il ne le fait pas, et le message d'erreur que j'obtiens est tout à fait inutile.

Si, en essayant d'envoyer le passeport d'objet de l'un des itinéraires, je comprends devrait être juste pour définir

var users = require('./routes/users')(app, passport);

Qui jette un défaut au démarrage

> /Users/bengtbjorkberg/.nvm/versions/node/v0.12.0/bin/node app.js Test
> something 2
> /Users/bengtbjorkberg/WebstormProjects/goMinute/node_modules/express/lib/router/index.js:130
> var search = 1 + req.url.indexOf('?');
>                           ^ TypeError: Cannot read property 'indexOf' of undefined
>     at Function.proto.handle (/Users/bengtbjorkberg/WebstormProjects/goMinute/node_modules/express/lib/router/index.js:130:27)
>     at router (/Users/bengtbjorkberg/WebstormProjects/goMinute/node_modules/express/lib/router/index.js:35:12)
>     at Object.<anonymous> (/Users/bengtbjorkberg/WebstormProjects/goMinute/app.js:41:38)
>     at Module._compile (module.js:460:26)
>     at Object.Module._extensions..js (module.js:478:10)
>     at Module.load (module.js:355:32)
>     at Function.Module._load (module.js:310:12)
>     at Function.Module.runMain (module.js:501:10)
>     at startup (node.js:129:16)
>     at node.js:814:3
> 
> Process finished with exit code 1

Si je retirer de l'app et de passeport, le problème disparaît comme par magie. les tracés ./routes/les utilisateurs de ne pas utiliser l'un d'eux encore.

J'ai ajouté une partie du code (a enlevé un peu de passeport de configuration pour la bonne forme)

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var methodOverride = require('method-override'); //simulate DELETE and PUT (express4)
var stylus = require('stylus');
var nib = require('nib');
var morgan = require('morgan');
// express session and passport
var session = require('express-session');
var passport = require('passport');
var flash    = require('connect-flash');
var app = express();
function compile(str, path) {
return stylus(str)
.set('filename', path)
.use(nib())
}
//view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
var accesslevels = require('./config/accesslevels.js');
console.log("Test something " + accesslevels.userRoles.user);
//required for passport
app.use(session({ secret: '' + 'asifIwouldtellstackoverflowright', resave: true, saveUninitialized: true })); //session secret
app.use(passport.initialize());
app.use(passport.session()); //persistent login sessions
app.use(flash()); //use connect-flash for flash messages stored in session
//Routes after passports
var routes = require('./routes/index');
var users = require('./routes/users')(app, passport);
var loginsrv = require('./routes/login');
var api = require('./routes/api');
var partials = require('./routes/partials');
var auth = function(req, res, next) {
if (!req.isAuthenticated())
res.send(401);
else
next();
};
//See more at: https://vickev.com/#!/article/authentication-in-single-page-applications-node-js-passportjs-angularjs
//uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json()); //get information from html forms
app.use(bodyParser.urlencoded({ extended: true }));
app.use(cookieParser());
app.use(require('stylus').middleware(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
app.use('/', routes);
app.use('/users', users);
app.use('/partials', partials);
app.use('/loginsrv', loginsrv);
//app.use(accesslevels());
//console.log(accesslevels);
//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;
app.listen(30010);

EDIT: Ajouté routes/users.js

var express = require('express');
var router = express.Router();
/* GET users listing. */
router.get('/', function(req, res, next) {
res.send('respond with a resource');
});
/*
//route to test if the user is logged in or not
router.get('/loggedin', function(req, res) {
res.send(req.isAuthenticated() ? req.user : '0');
});
router.post('/login', passport.authenticate('local'), function(req, res) {
res.send(req.user);
});
router.post('/logout', function(req, res){
req.logOut();
res.send(200);
});
*/
module.exports = router;

Dans le code ci-dessus, j'ai changé l'original router.get('/', function(req, res, next) avec router.get('/', function(app, passport, req, res, next) ce qui résout le problème.

Quelle est la portée de req?
Ce n' ./routes/users.js contenir?
mscdex, rien, avoir un peu de code, j'avais l'intention de s'exécuter, mais il est commenté en ce moment (car elle a besoin de passeport objet configuré dans le nœud principal de la partie).
PM, autant que je sache, le champ d'application de require serait mondial, pense que c'est une partie de node.js lui-même (peut-être tort), je suis assez certain que je ne change pas de valeur par défaut.

OriginalL'auteur vrghost | 2015-03-26