2014-06-28 14 views
7

ho creato un'applicazione conAvvio applicazione Node.js espresso

$ express -c stylus express_example 

posso iniziare il mio server con

$ npm start 

ma

$ node app.js 

&

$ nodemon app.js 

non sembrano funzionare. Tuttavia, non ricevo alcun messaggio di errore, il terminale passa alla riga successiva. per esempio.

$ node app.js 
$ 

Questo è il mio file bin/www

#!/usr/bin/env node 
var debug = require('debug')('my-application'); 
var app = require('../app'); 

app.set('port', process.env.PORT || 3000); 

var server = app.listen(app.get('port'), function() { 
    debug('Express server listening on port ' + server.address().port); 
}); 

e limare le app.js

var express = require('express'); 
var path = require('path'); 
var favicon = require('static-favicon'); 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 

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'); 

app.use(favicon()); 
app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded()); 
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); 

/// catch 404 and forwarding 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; 
+0

si riceve qualche messaggio di errore? – soulcheck

+0

pubblica la tua app.js – soulcheck

risposta

14

Capito. Dal momento che il mio server è avviato nel file bin/www in contrasto con il file app.js, dal terminale sono andato nella mia directory bin e poi chiamato

$ node wwww 

o

$ nodemon www 
3

tuo npm start probabilmente chiamate il file bin/www. Che contiene la chiamata listen per avviare la tua app.

Molte persone impostano la loro app in questo modo. per esempio. app.js per definire e configurare la loro app, e qualcosa come bin/www per ottenere effettivamente il server in esecuzione. In questo modo possono includere lo app.js in altre parti, ad esempio test, senza effettivamente avviare il server quando lo si usa.

1

avete in il file package.json contiene una proprietà in cui è possibile indicare il punto di ingresso della propria applicazione. Ad esempio:

"scripts": { 
    "start": "node ./bin/www" 
} 
Problemi correlati