日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

Node.js:路由

發(fā)布時間:2023/11/27 生活经验 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Node.js:路由 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
ylbtech-Node.js:路由

?

1.返回頂部
1、

Node.js 路由

我們要為路由提供請求的 URL 和其他需要的 GET 及 POST 參數(shù)隨后路由需要根據(jù)這些數(shù)據(jù)來執(zhí)行相應(yīng)的代碼。

因此,我們需要查看 HTTP 請求,從中提取出請求的 URL 以及 GET/POST 參數(shù)。這一功能應(yīng)當屬于路由還是服務(wù)器(甚至作為一個模塊自身的功能)確實值得探討,但這里暫定其為我們的HTTP服務(wù)器的功能。

我們需要的所有數(shù)據(jù)都會包含在 request 對象中,該對象作為 onRequest() 回調(diào)函數(shù)的第一個參數(shù)傳遞。但是為了解析這些數(shù)據(jù),我們需要額外的 Node.JS 模塊,它們分別是 url 和 querystring 模塊

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

當然我們也可以用 querystring 模塊來解析 POST 請求體中的參數(shù),稍后會有演示。

現(xiàn)在我們來給 onRequest() 函數(shù)加上一些邏輯,用來找出瀏覽器請求的 URL 路徑:

server.js 文件代碼:

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;

好了,我們的應(yīng)用現(xiàn)在可以通過請求的 URL 路徑來區(qū)別不同請求了--這使我們得以使用路由(還未完成)來將請求以 URL 路徑為基準映射到處理程序上。

在我們所要構(gòu)建的應(yīng)用中,這意味著來自 /start 和 /upload 的請求可以使用不同的代碼來處理。稍后我們將看到這些內(nèi)容是如何整合到一起的。

現(xiàn)在我們可以來編寫路由了,建立一個名為?router.js?的文件,添加以下內(nèi)容:

router.js 文件代碼:

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

如你所見,這段代碼什么也沒干,不過對于現(xiàn)在來說這是應(yīng)該的。在添加更多的邏輯以前,我們先來看看如何把路由和服務(wù)器整合起來。

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

首先,我們來擴展一下服務(wù)器的 start() 函數(shù),以便將路由函數(shù)作為參數(shù)傳遞過去,server.js?文件代碼如下

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;

同時,我們會相應(yīng)擴展 index.js,使得路由函數(shù)可以被注入到服務(wù)器中:

index.js 文件代碼:

var server = require("./server");
var router = require("./router");server.start(router.route);

在這里,我們傳遞的函數(shù)依舊什么也沒做。

如果現(xiàn)在啟動應(yīng)用(node index.js,始終記得這個命令行),隨后請求一個URL,你將會看到應(yīng)用輸出相應(yīng)的信息,這表明我們的HTTP服務(wù)器已經(jīng)在使用路由模塊了,并會將請求的路徑傳遞給路由:

$ node index.js
Server has started.

以上輸出已經(jīng)去掉了比較煩人的 /favicon.ico 請求相關(guān)的部分。

瀏覽器訪問?http://127.0.0.1:8888/,輸出結(jié)果如下:

2、
2.返回頂部
3.返回頂部
4.返回頂部
5.返回頂部
1、 http://www.runoob.com/nodejs/nodejs-router.html 2、
6.返回頂部
作者:ylbtech
出處:http://ylbtech.cnblogs.com/
本文版權(quán)歸作者和博客園共有,歡迎轉(zhuǎn)載,但未經(jīng)作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權(quán)利。

轉(zhuǎn)載于:https://www.cnblogs.com/storebook/p/8707196.html

總結(jié)

以上是生活随笔為你收集整理的Node.js:路由的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。