Express 4.x answer:
Express 4.x (for each Tien Do answer below) now treats app.listen () as an asynchronous operation, so listener.address () will only return data inside the app.listen () callback:
var app = require('express')(); var listener = app.listen(8888, function(){ console.log('Listening on port ' + listener.address().port);
Express 3 answer:
I think you are looking for this (express specific?):
console.log("Express server listening on port %d", app.address().port)
You may have seen this (bottom line) when you create the directory structure from the express command:
alfred@alfred-laptop:~/node$ express test4 create : test4 create : test4/app.js create : test4/public/images create : test4/public/javascripts create : test4/logs create : test4/pids create : test4/public/stylesheets create : test4/public/stylesheets/style.less create : test4/views/partials create : test4/views/layout.jade create : test4/views/index.jade create : test4/test create : test4/test/app.test.js alfred@alfred-laptop:~/node$ cat test4/app.js /** * Module dependencies. */ var express = require('express'); var app = module.exports = express.createServer(); // Configuration app.configure(function(){ app.set('views', __dirname + '/views'); app.use(express.bodyDecoder()); app.use(express.methodOverride()); app.use(express.compiler({ src: __dirname + '/public', enable: ['less'] })); app.use(app.router); app.use(express.staticProvider(__dirname + '/public')); }); app.configure('development', function(){ app.use(express.errorHandler({ dumpExceptions: true, showStack: true })); }); app.configure('production', function(){ app.use(express.errorHandler()); }); // Routes app.get('/', function(req, res){ res.render('index.jade', { locals: { title: 'Express' } }); }); // Only listen on $ node app.js if (!module.parent) { app.listen(3000); console.log("Express server listening on port %d", app.address().port) }
Alfred Jan 30 '11 at 12:28 2011-01-30 12:28
source share