欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

express.js中間件的示例分析

這篇文章將為大家詳細(xì)講解有關(guān)express.js中間件的示例分析,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

成都創(chuàng)新互聯(lián)專(zhuān)注于宛城網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供宛城營(yíng)銷(xiāo)型網(wǎng)站建設(shè),宛城網(wǎng)站制作、宛城網(wǎng)頁(yè)設(shè)計(jì)、宛城網(wǎng)站官網(wǎng)定制、成都微信小程序服務(wù),打造宛城網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供宛城網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。

express的新開(kāi)發(fā)人員往往對(duì)路由處理程序和中間件之間的區(qū)別感到困惑。因此他們也對(duì)app.use(),app.all(),app.get(),app.post(),app.delete()和app.put()方法的區(qū)別感到困惑。

在本文中,我將解釋中間件和路由處理程序之間的區(qū)別。以及如何正確使用app.use(),app.all(),app.get(),app.post(),app.delete()和app.put()方法。

路由處理

app.use(),app.all(),app.get(),app.post(),app.delete()和app.put()全部是用來(lái)定義路由的。這些方法都用于定義路由。路由用于處理HTTP請(qǐng)求。路由是路徑和回調(diào)的組合,在請(qǐng)求的路徑匹配時(shí)執(zhí)行?;卣{(diào)被稱為路由處理程序。

它們之間的區(qū)別是處理不同類(lèi)型的HTTP請(qǐng)求。例如: app.get()方法僅僅處理get請(qǐng)求,而app.all()處理GET、POST等請(qǐng)求。

下面是一個(gè)例子,如何定義一個(gè)路由:

var app = require("express")();

app.get("/", function(req, res, next){
  res.send("Hello World!!!!");
});

app.listen(8080);

每個(gè)路由處理程序都獲得對(duì)當(dāng)前正在提供的HTTP請(qǐng)求的請(qǐng)求和響應(yīng)對(duì)象的引用。

可以為單個(gè)HTTP請(qǐng)求執(zhí)行多個(gè)路由處理程序。這是一個(gè)例子:

var app = require("express")();

app.get("/", function(req, res, next){
  res.write("Hello");
  next();
});

app.get("/", function(req, res, next){
  res.write(" World !!!");
  res.end();
});

app.listen(8080);

這里第一個(gè)句柄寫(xiě)入一些響應(yīng),然后調(diào)用next()。 next()方法用于調(diào)用與路徑路徑匹配的下一個(gè)路由處理程序。

路由處理程序必須結(jié)束請(qǐng)求或調(diào)用下一個(gè)路由處理程序。

我們還可以將多個(gè)路由處理程序傳遞給app.all(),app.get(),app.post(),app.delete()和app.put()方法。

這是一個(gè)證明這一點(diǎn)的例子:

var app = require("express")();

app.get("/", function(req, res, next){
  res.write("Hello");
  next();
}, function(req, res, next){
  res.write(" World !!!");
  res.end();
});

app.listen(8080);

中間件

中間件是一個(gè)位于實(shí)際請(qǐng)求處理程序之上的回調(diào)。它采用與路由處理程序相同的參數(shù)。

要了解中間件,我們來(lái)看一個(gè)帶有dashboard和profile頁(yè)面的示例站點(diǎn)。要訪問(wèn)這些頁(yè)面,用戶必須登錄。還會(huì)記錄對(duì)這些頁(yè)面的請(qǐng)求。

以下是這些頁(yè)面的路由處理程序的代碼:

var app = require("express")();

function checkLogin(){
  return false;
}

function logRequest(){
  console.log("New request");
}

app.get("/dashboard", function(req, res, next){

  logRequest();

  if(checkLogin()){
    res.send("This is the dashboard page");
  }
  else{
    res.send("You are not logged in!!!");
  }
});

app.get("/profile", function(req, res, next){

  logRequest();

  if(checkLogin()){
    res.send("This is the dashboard page");
  }
  else{
    res.send("You are not logged in!!!");
  }
});

app.listen(8080);

這里的問(wèn)題是有很多重復(fù)的代碼,即我們不得不多次使用logRequest()和checkLogin()函數(shù)。這也使得更新代碼變得困難。因此,為了解決這個(gè)問(wèn)題,我們可以為這兩條路徑編寫(xiě)一條通用路徑。

這是重寫(xiě)的代碼:

var app = require("express")();

function checkLogin(){
  return false;
}

function logRequest(){
  console.log("New request");
}

app.get("/*", function(req, res, next){
  logRequest();
  next();
})

app.get("/*", function(req, res, next){
  if(checkLogin()){
    next();
  }
  else{
    res("You are not logged in!!!");
  }
})

app.get("/dashboard", function(req, res, next){
  res.send("This is the dashboard page");
});

app.get("/profile", function(req, res, next){
  res.send("This is the dashboard page");
});

app.listen(8080);

這里的代碼看起來(lái)更清晰,更易于維護(hù)和更新。這里將前兩個(gè)定義的路由處理程序稱為中間件,因?yàn)樗鼈儾惶幚碚?qǐng)求,而是負(fù)責(zé)預(yù)處理請(qǐng)求。

Express為我們提供了app.use()方法,該方法專(zhuān)門(mén)用于定義中間件。 app.use()方法可能看起來(lái)與app.all()類(lèi)似,但它們之間存在很多差異,這使得app.use()非常適合于聲明中間件。讓我們看看app.use()方法是如何工作的:

app.use() 和 app.all() 的不同:

CALLBACK

app.use()只需要一個(gè)回調(diào),而app.all()可以進(jìn)行多次回調(diào)。

PATH

app.use()只查看url是否以指定路徑開(kāi)頭,app.all()匹配完整路徑。

這里有一個(gè)例子來(lái)說(shuō)明:

app.use( "/product" , mymiddleware);
// will match /product
// will match /product/cool
// will match /product/foo

app.all( "/product" , handler);
// will match /product
// won't match /product/cool  <-- important
// won't match /product/foo  <-- important

app.all( "/product/*" , handler);
// won't match /product    <-- Important
// will match /product/cool
// will match /product/foo

NEXT()

中間件內(nèi)的next()調(diào)用下一個(gè)中間件或路由處理程序,具體取決于接下來(lái)聲明的那個(gè)。但是路由處理程序中的next()僅調(diào)用下一個(gè)路由處理程序。如果接下來(lái)有中間件,則跳過(guò)它。因此,必須在所有路由處理程序之前聲明中間件。

這里有一個(gè)例子來(lái)說(shuō)明:

var express = require('express');
var app = express();

app.use(function frontControllerMiddlewareExecuted(req, res, next){
 console.log('(1) this frontControllerMiddlewareExecuted is executed');
 next();
});

app.all('*', function(req, res, next){
 console.log('(2) route middleware for all method and path pattern "*", executed first and can do stuff before going next');
 next();
});

app.all('/hello', function(req, res, next){
 console.log('(3) route middleware for all method and path pattern "/hello", executed second and can do stuff before going next');
 next();
});

app.use(function frontControllerMiddlewareNotExecuted(req, res, next){
 console.log('(4) this frontControllerMiddlewareNotExecuted is not executed');
 next();
});

app.get('/hello', function(req, res){
 console.log('(5) route middleware for method GET and path patter "/hello", executed last and I do my stuff sending response');
 res.send('Hello World');
});

app.listen(80);

現(xiàn)在我們看到了app.use()方法的唯一性以及它用于聲明中間件的原因。

讓我們重寫(xiě)我們的示例站點(diǎn)代碼:

var app = require("express")();

function checkLogin(){
  return false;
}

function logRequest(){
  console.log("New request");
}

app.use(function(req, res, next){
  logRequest();
  next();
})

app.use(function(req, res, next){

  if(checkLogin()){
    next();
  }
  else{
    res.send("You are not logged in!!!");
  }
})

app.get("/dashboard", function(req, res, next){
  res.send("This is the dashboard page");
});

app.get("/profile", function(req, res, next){
  res.send("This is the dashboard page");
});

app.listen(8080);

關(guān)于“express.js中間件的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

當(dāng)前題目:express.js中間件的示例分析
本文URL:http://aaarwkj.com/article8/igjhip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、小程序開(kāi)發(fā)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、電子商務(wù)、外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
日本熟妇中文字幕系列| 国产成人啪精品视频免费| 国产精品人妻在线av| 蜜臀在线观看免费视频| 麻豆专区一区二区三区| 久久久国产精品视频一区| 2020中文字字幕在线不卡| 亚洲国产视频中文字幕| 中文字幕精品免费日韩在线| 黑人巨大精品欧美久久| 亚洲精品丝袜成人偷拍| 97国产超碰在线观看| 黄色亚洲一区二区三区四区| 欧美aⅴ精品一区二区三区| 精品亚洲午夜久久久久| 免费人成网站在线观看| 香蕉网性欧美在线视频| 无遮挡动漫网站免费观看| 日韩爱爱特级视频中文字幕| 国产一级内射麻豆91| 欧美熟女av在线观看| 亚洲特级黄色做啪啪啪| 日本加勒比中文在线观看| 少妇视频资源一区二区三区| 九九九热精品在线视频观看| 色综合色狠狠天天综合色| 久久中文字幕人妻熟av| 高清免费欧美大片在线观看| 欧美亚洲综合激情在线| 国产高清av免费在线播放| 看看美女阴逼毛茸茸的| 欧美激情亚洲一区二区| 亚洲国产黄色美女视频| 国内一级片内射免费视频观看| 2004年亚洲中文字幕| 国产亚洲一区二区三区乱码| 日本中文一区在线观看| 日韩高清午夜片在线观看| 日韩视频一区二区三区系列| 中文字幕人妻紧贴拍摄| 在线激情av中文字幕|