摘要:最終我們啟動命令行輸入隨后請求一個(gè)我們就會看到應(yīng)用輸出相應(yīng)對信息,這表明我們對服務(wù)器已經(jīng)在使用路由模塊了。并會將請求對路徑傳遞給路由,再由路由進(jìn)行接下來對操作。
Node.js 路由
我們平時(shí)工作中,涉及到后臺開發(fā),路由基本上是我們第一個(gè)需要建的,路由還是很重要的。
那么,什么是路由呢,通俗點(diǎn)舉個(gè)例子,一個(gè)賓館前臺,來了十位客人,前臺會安排十位客人入住,每位客人到達(dá)賓館以后,該去哪個(gè)房間,都是通過前臺來安排。(別噴我)
在一個(gè)域名下,會有很多個(gè)可訪問的地址,這就是路由。
我們呢,要為路由提供請求的URL和其他需要的GET及POST參數(shù),隨后路由需要根據(jù)這些數(shù)據(jù),來決定執(zhí)行哪些代碼。/
因此,我們要查看HTTP請求,從中提取出來我們需要的URL以及GET/POST參數(shù)。
我們需要的這些數(shù)據(jù)都會包含在request對象中,該對象作為onRequest()回調(diào)函數(shù)的第一個(gè)參數(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)在我們寫一段代碼,用來找出瀏覽器請求的URL路徑 之前也寫到如何用node起serve
我們新建一個(gè)server.js 代碼如下
// 代碼route()方法為第二個(gè)創(chuàng)建的router.js那的方法。我們在這里使用 const http = require("http") const url = require("url") function start(route){ function onRequest(request, response) { let pathName = url.parse(request.url).pathname // 通過url獲取到當(dāng)前訪問路徑 console.log("Request for " + pathName + "received.") route(pathName,response) } http.createServer(onRequest).listen(8888) console.log("Server has started") } exports.start = start
然后創(chuàng)建router.js
// 通過傳遞過來到pathname,來進(jìn)行不同的操作,如果是根目錄,打印hello world // 如果是/index 打印 pathname :/index // 如果是其他 打印404 function route(pathname,response) { console.log("About to route a request for " + pathname) response.writeHead(200, {"Content-Type" : "text/plain"}) if(pathname == "/") { response.write("Hello World") response.end() }else if(pathname == "/index"){ response.write("pathname :/index") response.end() } else { response.write("404") response.end() } } exports.route = route
真實(shí)環(huán)境肯定不會這么寫,這樣寫主要是理解路由的工作原理
接下來我們創(chuàng)建index.js 倒入我們寫好的兩個(gè)模塊。
const server = require("./server") const router = require("./router") server.start(router.route)
調(diào)用server下的start方法,把router那的route方法傳入進(jìn)去。整體的邏輯就出來了,
通過server.js 創(chuàng)建http服務(wù),通過node內(nèi)置模塊url獲取到當(dāng)前訪問路徑,在通過router.js 對不同訪問路徑進(jìn)行不同對代碼操作。
最終我們啟動命令行 輸入node index.js 隨后請求一個(gè)url 我們就會看到應(yīng)用輸出相應(yīng)對信息,這表明我們對HTTP服務(wù)器已經(jīng)在使用路由模塊了。并會將請求對路徑傳遞給路由,再由路由進(jìn)行接下來對操作。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104404.html
摘要:原生應(yīng)用是一個(gè)基于引擎的運(yùn)行環(huán)境使用了一個(gè)事件驅(qū)動非阻塞式的模型,使其輕量又高效的包管理器,是全球最大的開源庫生態(tài)系統(tǒng)本文主要介紹構(gòu)建一個(gè)應(yīng)用的基本步驟和模塊,并假定你已經(jīng)對有一定的了解本文引用部分代碼作為例子,如果希望參看全部源碼,歡迎去 原生 Node.js 應(yīng)用 Node.js 是一個(gè)基于 Chrome V8 引擎的 JavaScript 運(yùn)行環(huán)境Node.js 使用了一個(gè)事件驅(qū)...
路由koa-router——MVC 中重要的環(huán)節(jié):Url 處理器 ?? iKcamp 制作團(tuán)隊(duì) 原創(chuàng)作者:大哼、阿干、三三、小虎、胖子、小哈、DDU、可木、晃晃 文案校對:李益、大力萌、Au、DDU、小溪里、小哈 風(fēng)采主播:可木、阿干、Au、DDU、小哈 視頻剪輯:小溪里 主站運(yùn)營:給力xi、xty 教程主編:張利濤 視頻地址:https://www.cctalk.com/v/151...
摘要:原生開發(fā)入門完全教程微信公眾號開發(fā)企業(yè)級產(chǎn)品全棧開發(fā)速成周末班首期班號正式開班,歡迎搶座一關(guān)于本篇文章參考了入門并從零到壹操作了一遍,感謝原作者,同時(shí)也強(qiáng)烈推薦大家移步到原文給予原文作者一個(gè)贊賞支持。 Node.js原生開發(fā)入門完全教程 (Node+Vue+React+微信公眾號開發(fā))企業(yè)級產(chǎn)品全棧開發(fā)速成周末班首期班(10.28號正式開班,歡迎搶座) 一、關(guān)于 本篇文章參考了Node...
摘要:前言這是一個(gè)基于實(shí)現(xiàn)的一個(gè)簡單登入例子,對于剛上手想進(jìn)一步了解,前端頁面如何請求到服務(wù)層路由處理數(shù)據(jù)庫操作返回結(jié)果到頁面這整個(gè)過程的同學(xué)比較有用。我們來看下登入請求處理。操作演示演示用戶名不存在,密碼錯(cuò)誤及成功登入。 前言 這是一個(gè)基于node實(shí)現(xiàn)的一個(gè)簡單登入例子,對于剛上手node想進(jìn)一步了解,前端頁面如何請求到服務(wù)層 -> 路由處理 -> 數(shù)據(jù)庫操作 -> 返回結(jié)果到頁面這整個(gè)過...
摘要:一個(gè)標(biāo)準(zhǔn)性的事件就是年的橫空出世。引擎快速處理能力和異步編程風(fēng)格,讓開發(fā)者從多線程中解脫了出來。其次,通過異步編程范式將其高并發(fā)的能力發(fā)揮的淋漓盡致。它也僅僅是一個(gè)處理請求并作出響應(yīng)的函數(shù),并無任何特殊之處。 showImg(https://segmentfault.com/img/remote/1460000010819116); 在正式學(xué)習(xí) Express 內(nèi)容之前,我們有必要從大...
閱讀 1767·2021-11-24 09:39
閱讀 1692·2021-11-22 15:22
閱讀 1015·2021-09-27 13:36
閱讀 3264·2021-09-24 10:34
閱讀 3344·2021-07-26 23:38
閱讀 2639·2019-08-29 16:44
閱讀 981·2019-08-29 16:39
閱讀 1113·2019-08-29 16:20