DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 輕松創建nodejs服務器(4):路由
輕松創建nodejs服務器(4):路由
編輯:關於JavaScript     

服務器需要根據不同的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請求給予不同的反饋。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved