日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

中國最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2

nodejs教程

Node.js 路由

閱讀 (2332)

Node.js 路由

我們要為路由提供請求的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()函數,以便將路由函數作為參數傳遞過去:

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服務器已經在使用路由模塊了,并會將請求的路徑傳遞給路由:

bash$ node index.js
Request for /foo received.
About to route a request for /foo

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

關閉
程序員人生
主站蜘蛛池模板: 国产伦精品一区二区三区精品视频 | 亚洲免费视频一区二区 | av在线播放免费 | 99在线精品免费视频 | 国产精品美女一区二区 | 中文字幕在线视频一区 | 中文字幕av一区二区三区 | 国产精品亚洲第一 | 免费的毛片视频 | 少妇精品久久久久www蜜月 | 老司机成人 | 韩日成人 | 久久国产精品区 | 91久久久国产精品 | 在线一级黄色片 | 国产精品美女久久久 | 国产精品久久中文字幕 | 亚洲精品久久久久中文字幕欢迎你 | 精品一二区 | 成人福利在线观看 | 日韩精品中文字幕一区二区 | 亚洲毛片一区二区 | 日韩欧美片 | 亚洲视频免费观看 | 精品国产一区二区三区久久 | 99九九久久| 国产一区二区精品久久 | 精品亚洲国产成av人片传媒 | 操女人在线 | 一区二区三区精品在线 | 久久三级网 | 国产精品18久久久久久久久久久久 | 欧美综合国产 | 久久精品视频网站 | 国产精品99久久久 | 日韩一区精品 | 精品国产第一国产综合精品 | 在线一区视频 | 久热99 | 国产精品成人国产乱一区 | av免费在线网站 |