服務(wù)器需要根據(jù)不同的URL或請求來執(zhí)行不一樣的操作,我們可以通過路由來實現(xiàn)這個步驟。
第一步我們需要先解析出請求URL的路徑,我們引入url模塊。
我們來給onRequest()函數(shù)加上一些邏輯,用來找出瀏覽器請求的URL路徑:
var http = require("http");
var url = require("url");
function start() {
function onRequest(request, response) {
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World");
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start = start;
好了,pathname就是請求的路徑,我們可以用它來區(qū)別不同請求了,這樣一來我們就可以對來自/start和/upload的請求使用不同的代碼來處理。
接著我們來編寫路由,建立一個名為router.js的文件,代碼如下:
function route(pathname) {
console.log("About to route a request for " + pathname);
}
exports.route = route;
這段代碼什么都沒干,我們先把路由和服務(wù)器整合起來。
我們接著擴展服務(wù)器的start()函數(shù),在start()中運行路由函數(shù),并將pathname作為參數(shù)傳給它。
var http = require("http");
var url = require("url");
function start(route) {
function onRequest(request, response) {
var pathname = url.parse(request.url).pathname;
console.log("Request for " + pathname + " received.");
route(pathname);
response.writeHead(200, {"Content-Type": "text/plain"});
response.write("Hello World");
response.end();
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
exports.start = start;
同時,我們會相應(yīng)擴展index.js,使得路由函數(shù)可以被注入到服務(wù)器中:
var server = require("./server");
var router = require("./router");
server.start(router.route);
運行index.js,隨便訪問個路徑,比如/upload,就會發(fā)現(xiàn)控制臺輸出,About to route a request for /upload.
這就意味著我們的HTTP服務(wù)器和請求路由模塊已經(jīng)可以相互交流了。
下一節(jié)我們將實現(xiàn)針對不同的URL請求給予不同的反饋。