首先說一下,上篇文章中安裝的node,是一個javascript服務(wù)器運行環(huán)境。其封裝了javascript寫的包.node沒有監(jiān)聽服務(wù)器端口,而實際是通過
,建立一個server.js監(jiān)聽文件,用node進行運行,監(jiān)聽對應(yīng)的端口,并執(zhí)行相關(guān)操作。
然后說一下,上次運行的代碼:
var http = require("http");//引入http請求模塊,以后還會有url模塊等
http.createServer(function(request, response)
{ response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World"); response.end();
}).listen(9999);//將句柄進行端口9999監(jiān)聽,并執(zhí)行匿名函數(shù),函數(shù)的參數(shù)為request和response
轉(zhuǎn)換一下:
var http = require("http");
function listen(request.response){
response.writeHead(200,{"Content-Type":"text/plain"});//函數(shù)發(fā)送一個HTTP狀態(tài)200和HTTP頭的內(nèi)容類型(content-type),
response.write("Hello World");//使用 response.write() 函數(shù)在HTTP相應(yīng)主體中發(fā)送文本“Hello World"。
response.end();
}
http.createServer(listen).listen(9999);//創(chuàng)建監(jiān)聽服務(wù),以及監(jiān)聽處理函數(shù)
當運行node server.js后,node主動監(jiān)聽9999端口,當請求來時,則會調(diào)用listen函數(shù)。這里可以將我們server.js理解為一個等待請求服務(wù)的程
序。
如何將server.js 當做一個模塊去引入,就像php引入公共文件一樣呢?
將上面的代碼封裝到一個函數(shù)
var http = require("http");
function servername(){
function listen(request.response){
response.writeHead(200,{"Content-Type":"text/plain"});//函數(shù)發(fā)送一個HTTP狀態(tài)200和HTTP頭的內(nèi)容類型( content-type),
response.write("Hello World");//使用 response.write() 函數(shù)在HTTP相應(yīng)主體中發(fā)送文本“Hello World"。
response.write("server Caller");
response.end();
}
http.createServer(listen).listen(9999);//創(chuàng)建監(jiān)聽服務(wù),以及監(jiān)聽處理函數(shù)
}
exports.start = servername;//對外接口為servername函數(shù)
在同級文件夾 建立一個index.js文件,內(nèi)容為:
var server = require("./server")
server.start();
保存index.js文件
然后運行 node index.js 這時候你再次訪問9999端口,你也會看到helloworld,并且看到是server Caller.
更多信息請查看IT技術(shù)專欄