Node.js 路由

來源:互聯網
上載者:User

標籤:

 

我們要為路由提供請求的URL和其他需要的GET及POST參數,隨後路由需要根據這些資料來執行相應的代碼。

因此,我們需要查看HTTP請求,從中提取出請求的URL以及GET/POST參數。這一功能應當屬於路由還是伺服器(甚至作為一個模組自身的功能)確實值得探討,但這裡暫訂其為我們的HTTP伺服器的功能。

我們需要的所有資料都會包含在request對象中,該對象作為onRequest()回呼函數的第一個參數傳遞。但是為瞭解析這些資料,我們需要額外的Node.JS模組,它們分別是url和querystring模組。

                   url.parse(string).query                                           |           url.parse(string).pathname      |                       |                   |                       |                   |                     ------ -------------------http://localhost:8888/start?foo=bar&hello=world                                ---       -----                                 |          |                                 |          |              querystring(string)["foo"]    |                                            |                         querystring(string)["hello"]

當然我們也可以用querystring模組來解析POST請求體中的參數,稍後會有示範。

現在我們來給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;

好了,我們的應用現在可以通過請求的URL路徑來區別不同請求了--這使我們得以使用路由(還未完成)來將請求以URL路徑為基準映射到處理常式上。

在我們所要構建的應用中,這意味著來自/start和/upload的請求可以使用不同的代碼來處理。稍後我們將看到這些內容是如何整合到一起的。

現在我們可以來編寫路由了,建立一個名為 router.js 的檔案,添加以下內容:

function route(pathname) {  console.log("About to route a request for " + pathname);}exports.route = route;

如你所見,這段代碼什麼也沒幹,不過對於現在來說這是應該的。在添加更多的邏輯以前,我們先來看看如何把路由和伺服器整合起來。

我們的伺服器應當知道路由的存在並加以有效利用。我們當然可以通過硬式編碼方式將這一依賴項綁定到伺服器上,但是其它語言的編程經驗告訴我們這會是一件非常痛苦的事,因此我們將使用依賴注入的方式較鬆散地添加路由模組。

首先,我們來擴充一下伺服器的start()函數,以便將路由函數作為參數傳遞過去,server.js 檔案代碼如下

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);

在這裡,我們傳遞的函數依舊什麼也沒做。

如果現在啟動應用(node index.js,始終記得這個命令列),隨後請求一個URL,你將會看到應用輸出相應的資訊,這表明我們的HTTP伺服器已經在使用路由模組了,並會將請求的路徑傳遞給路由:

$ node index.jsServer has started.

以上輸出已經去掉了比較煩人的/favicon.ico請求相關的部分。

瀏覽器訪問 http://127.0.0.1:8888/,輸出結果如下:

Node.js 路由

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.