欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

輕松創(chuàng)建nodejs服務(wù)器(4):路由

 更新時(shí)間:2014年12月18日 09:57:05   投稿:junjie  
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來執(zhí)行不一樣的操作,我們可以通過路由來實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下

服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來執(zhí)行不一樣的操作,我們可以通過路由來實(shí)現(xiàn)這個(gè)步驟。

第一步我們需要先解析出請(qǐng)求URL的路徑,我們引入url模塊。

我們來給onRequest()函數(shù)加上一些邏輯,用來找出瀏覽器請(qǐng)求的URL路徑:

復(fù)制代碼 代碼如下:

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的文件,代碼如下:

復(fù)制代碼 代碼如下:

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ù)傳給它。

復(fù)制代碼 代碼如下:

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ù)器中:

復(fù)制代碼 代碼如下:

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)求給予不同的反饋。

相關(guān)文章

  • Nodejs中執(zhí)行的shell命令的代碼分享

    Nodejs中執(zhí)行的shell命令的代碼分享

    雖然nodejs運(yùn)行時(shí)提供了和OS交互的諸多API命令,但是有些操作(例如:特定系統(tǒng)信息獲?。┻€是使用shell命令更加方便一些,下面就跟隨小編一起來看看有哪些是宜在nodejs中執(zhí)行的shell代碼吧
    2024-02-02
  • node+express+ejs使用模版引擎做的一個(gè)示例demo

    node+express+ejs使用模版引擎做的一個(gè)示例demo

    本篇文章主要介紹了node+express+ejs使用模版引擎做的一個(gè)示例demo,具有一定參考價(jià)值,有興趣的小伙伴可以了解一下
    2017-09-09
  • express中static中間件的具體使用方法

    express中static中間件的具體使用方法

    這篇文章主要介紹了express中static中間件的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Node.js DES加密的簡單實(shí)現(xiàn)

    Node.js DES加密的簡單實(shí)現(xiàn)

    下面小編就為大家?guī)硪黄狽ode.js DES加密的簡單實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-07-07
  • jwt在node中的應(yīng)用實(shí)踐(安裝配置封裝)

    jwt在node中的應(yīng)用實(shí)踐(安裝配置封裝)

    這篇文章主要為大家介紹了jwt在node中的應(yīng)用實(shí)踐包括安裝配置封裝,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • 淺談Node Inspector 代理實(shí)現(xiàn)

    淺談Node Inspector 代理實(shí)現(xiàn)

    這篇文章主要介紹了淺談Node Inspector 代理實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • node.js中的fs.realpathSync方法使用說明

    node.js中的fs.realpathSync方法使用說明

    這篇文章主要介紹了node.js中的fs.realpathSync方法使用說明,本文介紹了fs.realpathSync的方法說明、語法、接收參數(shù)、使用實(shí)例和實(shí)現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • nodejs使用express創(chuàng)建一個(gè)簡單web應(yīng)用

    nodejs使用express創(chuàng)建一個(gè)簡單web應(yīng)用

    這篇文章主要介紹了nodejs使用express創(chuàng)建一個(gè)簡單web應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • nodejs下載指定版本完整圖文步驟

    nodejs下載指定版本完整圖文步驟

    node.js官方版是一款專業(yè)性非常強(qiáng)的瀏覽輔助工具軟件,這款軟件操作十分的簡單、功能也是非常的強(qiáng)勁,下面這篇文章主要給大家介紹了關(guān)于nodejs下載指定版本的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • 配置Node.js環(huán)境變量詳細(xì)圖文教程

    配置Node.js環(huán)境變量詳細(xì)圖文教程

    這篇文章主要給大家介紹了關(guān)于配置Node.js環(huán)境變量詳細(xì)圖文教程的相關(guān)資料,在Node.js中設(shè)置環(huán)境變量非常簡單,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11

最新評(píng)論