參考:
一、Intellj Idea下的初始工程
使用Idea創建的Node.js Express工程創建成功后運行,
訪問localhost:3000即可以看到如下頁面:
二、代碼分析
第一個工程命名為PageIron,該專案的主要代碼位于PageIron/bin/www檔案中:
Node.js 應用的組成部分:
引入 required 模塊:我們可以使用 require 指令來載入 Node.js 模塊。
創建服務器:服務器可以監聽客戶端的請求,類似于 Apache 、Nginx 等 HTTP 服務器。
接收請求與回應請求
代碼如下:
1. required模塊:
/**
* Module dependencies.
*/
var app = require('../app');
var debug = require('debug')('pageiron:server');
var http = require('http');
2.創建服務器
/**
* Get port from environment and store in Express.
*/
var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);
/**
* Create HTTP server.
*/
var server = http.createServer(app);
3. 接受請求和相應
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
var bind = typeof port === 'string'
? 'Pipe ' + port
: 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
/**
* Event listener for HTTP server "listening" event.
*/
function onListening() {
var addr = server.address();
var bind = typeof addr === 'string'
? 'pipe ' + addr
: 'port ' + addr.port;
debug('Listening on ' + bind);
}
三、Node.js實體
如下是一個Node.js創建的實體:
var events = require('events');
var eventsEmmiter = new events.EventEmitter();
var connectHandler = function connected(){
console.log('connected');
eventsEmmiter.emit('data_received');
}
eventsEmmiter.on('connection', connectHandler);
eventsEmmiter.on('data_received', function(){
console.log("資料接收成功");
});
eventsEmmiter.emit('connection');
console.log('程式執行完畢');
代碼檔案命名為main.js,使用如下命令運行:
$ node main.js結果如下:
connected
資料接收成功
程式執行完
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/144405.html
標籤:應用服務器
上一篇:npm run dev 報錯問題
