輕松創(chuàng)建nodejs服務(wù)器(4):路由
服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來執(zhí)行不一樣的操作,我們可以通過路由來實(shí)現(xiàn)這個(gè)步驟。
第一步我們需要先解析出請(qǐng)求URL的路徑,我們引入url模塊。
我們來給onRequest()函數(shù)加上一些邏輯,用來找出瀏覽器請(qǐng)求的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就是請(qǐng)求的路徑,我們可以用它來區(qū)別不同請(qǐng)求了,這樣一來我們就可以對(duì)來自/start和/upload的請(qǐng)求使用不同的代碼來處理。
接著我們來編寫路由,建立一個(gè)名為router.js的文件,代碼如下:
function route(pathname) {
console.log("About to route a request for " + pathname);
}
exports.route = route;
這段代碼什么都沒干,我們先把路由和服務(wù)器整合起來。
我們接著擴(kuò)展服務(wù)器的start()函數(shù),在start()中運(yùn)行路由函數(shù),并將pathname作為參數(shù)傳給它。
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;
同時(shí),我們會(huì)相應(yīng)擴(kuò)展index.js,使得路由函數(shù)可以被注入到服務(wù)器中:
var server = require("./server");
var router = require("./router");
server.start(router.route);
運(yùn)行index.js,隨便訪問個(gè)路徑,比如/upload,就會(huì)發(fā)現(xiàn)控制臺(tái)輸出,About to route a request for /upload.
這就意味著我們的HTTP服務(wù)器和請(qǐng)求路由模塊已經(jīng)可以相互交流了。
下一節(jié)我們將實(shí)現(xiàn)針對(duì)不同的URL請(qǐng)求給予不同的反饋。
- 輕松創(chuàng)建nodejs服務(wù)器(1):一個(gè)簡單nodejs服務(wù)器例子
- 拋棄Nginx使用nodejs做反向代理服務(wù)器
- 輕松創(chuàng)建nodejs服務(wù)器(10):處理上傳圖片
- 輕松創(chuàng)建nodejs服務(wù)器(10):處理POST請(qǐng)求
- Nodejs實(shí)現(xiàn)的一個(gè)簡單udp廣播服務(wù)器、客戶端
- 使用nodejs、Python寫的一個(gè)簡易HTTP靜態(tài)文件服務(wù)器
- Nodejs實(shí)現(xiàn)的一個(gè)靜態(tài)服務(wù)器實(shí)例
- NodeJS學(xué)習(xí)筆記之Http模塊
- 搭建簡單的nodejs http服務(wù)器詳解
- NodeJS創(chuàng)建最簡單的HTTP服務(wù)器
相關(guān)文章
node+express+ejs使用模版引擎做的一個(gè)示例demo
本篇文章主要介紹了node+express+ejs使用模版引擎做的一個(gè)示例demo,具有一定參考價(jià)值,有興趣的小伙伴可以了解一下2017-09-09jwt在node中的應(yīng)用實(shí)踐(安裝配置封裝)
這篇文章主要為大家介紹了jwt在node中的應(yīng)用實(shí)踐包括安裝配置封裝,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09淺談Node Inspector 代理實(shí)現(xiàn)
這篇文章主要介紹了淺談Node Inspector 代理實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10node.js中的fs.realpathSync方法使用說明
這篇文章主要介紹了node.js中的fs.realpathSync方法使用說明,本文介紹了fs.realpathSync的方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下2014-12-12nodejs使用express創(chuàng)建一個(gè)簡單web應(yīng)用
這篇文章主要介紹了nodejs使用express創(chuàng)建一個(gè)簡單web應(yīng)用的相關(guān)資料,需要的朋友可以參考下2017-03-03