服務器需要根據不同的URL或請求來執行不一樣的操作,我們可以通過路由來實現這個步驟。
第一步我們需要先解析出請求URL的路徑,我們引入url模塊。
我們來給onRequest()函數加上一些邏輯,用來找出浏覽器請求的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就是請求的路徑,我們可以用它來區別不同請求了,這樣一來我們就可以對來自/start和/upload的請求使用不同的代碼來處理。
接著我們來編寫路由,建立一個名為router.js的文件,代碼如下:
代碼如下:
function route(pathname) {
console.log("About to route a request for " + pathname);
}
exports.route = route;
這段代碼什麼都沒干,我們先把路由和服務器整合起來。
我們接著擴展服務器的start()函數,在start()中運行路由函數,並將pathname作為參數傳給它。
代碼如下:
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;
同時,我們會相應擴展index.js,使得路由函數可以被注入到服務器中:
代碼如下:
var server = require("./server");
var router = require("./router");
server.start(router.route);
運行index.js,隨便訪問個路徑,比如/upload,就會發現控制台輸出,About to route a request for /upload.
這就意味著我們的HTTP服務器和請求路由模塊已經可以相互交流了。
下一節我們將實現針對不同的URL請求給予不同的反饋。