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

淺談express.js框架中間件(middleware)

 更新時(shí)間:2019年04月07日 10:44:53   作者:小龍  
這篇文章主要介紹了淺談express.js框架中間件(middleware),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

_express.js_作為_Node.js_的老牌框架,是現(xiàn)有框架中最全面的。然而在學(xué)習(xí)express除了那些api之外,對(duì)于框架最重要的就是__中間件__這個(gè)概念了。如果理解了,就可以把這個(gè)框架玩活了,項(xiàng)目開發(fā)肯定會(huì)更加順利,而且還可以開發(fā)很多額外的功能,甚至中間件擴(kuò)展開發(fā)。

但是就這么一個(gè)東西,是很多學(xué)習(xí)node.js的小萌新們就算寫出一個(gè)博客項(xiàng)目,都不知道它到底有啥作用。我當(dāng)時(shí)在理解的時(shí)候也花了不少功夫,趁著沒有啥工作,給各位學(xué)習(xí)express.js的一點(diǎn)點(diǎn)我的指導(dǎo)意見。當(dāng)然,這里面可能也有koa2和egg的忠實(shí)粉絲,但其實(shí)所有node框架貌似都有這個(gè)概念,所以我用express舉例子,希望各位將就一下哈,應(yīng)該都是可以看得懂的。

首先我先來一波官方的解釋:

好吧,被這些英語嚇到了,來一波譯文:

[中間件函數(shù)是可以訪問請(qǐng)求對(duì)象(req)、響應(yīng)對(duì)象(res)和應(yīng)用程序請(qǐng)求響應(yīng)周期中的下一個(gè)函數(shù)的函數(shù)。下一個(gè)函數(shù)是Express路由器中的一個(gè)函數(shù),當(dāng)調(diào)用該函數(shù)時(shí),它執(zhí)行當(dāng)前中間件之后的中間件。

中間件功能可以執(zhí)行以下任務(wù):

  • 執(zhí)行任何代碼
  • 對(duì)請(qǐng)求和響應(yīng)對(duì)象進(jìn)行更改。
  • 結(jié)束請(qǐng)求響應(yīng)周期。
  • 調(diào)用堆棧中的下一個(gè)中間件。

終于知道當(dāng)初的我為毛剛開始理解的時(shí)候很困難了,說實(shí)在的看得我真的有懵的。幸好,我還是從這個(gè)坑爬出來了,我來拉你們一把了。首先我們不去深究概念,直接上一個(gè)代碼塊。

如果我們啟動(dòng)服務(wù),訪問'/'路由,會(huì)返回"這是一個(gè)根路由",訪問router1路由就會(huì)得到這是一個(gè)"這是一個(gè)router1路由的"的信息。這看起來是一個(gè)很簡單的路由查詢,我們理一下過程,這個(gè)請(qǐng)求是如何訪問到這個(gè)路由的呢。

一般來說,一個(gè)express框架的項(xiàng)目會(huì)寫入很多路由,但各位要注意的是,這個(gè)請(qǐng)求并不是直接定位到這個(gè)路由的,而是一個(gè)從上至下匹配的一個(gè)過程。

有點(diǎn)亂?沒關(guān)系我們看圖

我們看到這幅圖,有一個(gè)箭頭,從上到下的。什么意思呢,如果用戶發(fā)了一個(gè)這樣的請(qǐng)求

GET '/router7'

那么他會(huì)從第一個(gè)開始一個(gè)一個(gè)去匹配,知道發(fā)現(xiàn)有一個(gè)路由名和請(qǐng)求方法都一致的路由,就立馬執(zhí)行里面的代碼,并且返回一段文字"這是一個(gè)router7路由"。這都很好理解,那么現(xiàn)在我有一個(gè)需求,就是不管訪問任何一個(gè)路由,我都要知道這個(gè)訪問者的ip地址和訪問的目標(biāo)路由打印出來,生產(chǎn)訪問日志。那么怎么做了。

我們分析一波,這段程序是所有的請(qǐng)求都要執(zhí)行的,如果按照?qǐng)?zhí)行順序的說法,那么這段程序是應(yīng)該放到所有路由的最前面的,也就是說這段程序是所有路由要經(jīng)過的一段程序,也就是我們所說的中間件。好的,廢話不多說,上代碼

const fs = require('fs')
const log = (req,res) => {
  const ip = req.ip,
     route = req.route.path
  const log = `ip:${ip} path:${route}`
   fs.writeFileSync(__dirname + '/log',log)
}

比如現(xiàn)在我有一個(gè)log函數(shù),它專門用來記錄訪問日志的。如何所有的都一起執(zhí)行了,我們加一段這樣的代碼

app.use(log)

它加在所有代碼的最上面,但是不是加上就完事了,還必須在log函數(shù)里面再加一段代碼,不然當(dāng)程序執(zhí)行到里面之后就出不去了,什么代碼了。我們重寫log函數(shù)

const log = (req,res,next) => {
  const ip = req.ip,
     route = req.route.path
  const log = `ip:${ip} path:${route}`
   fs.writeFileSync(__dirname + '/log',log)
   next()
}

大家有沒有看見那個(gè)next,它有什么作用了。前面我們提到,它其實(shí)就是一個(gè)過渡者,主要的作用其實(shí)就是經(jīng)過之后,要繼續(xù)往下面執(zhí)行,還是就此終止返回結(jié)果。

說的簡單一點(diǎn),就是我們一個(gè)http請(qǐng)求,到達(dá)我們的node服務(wù)器之后,要經(jīng)歷的過程,而每經(jīng)過一個(gè)程序塊,就是個(gè)中間件,每一個(gè)中間件只要有next就會(huì)傳遞到下一個(gè)中間件里面,直到服務(wù)器res響應(yīng)結(jié)果,整個(gè)路由就此結(jié)束。

我們整合一下代碼。并且精簡一下,也跑一遍程序

const express = require('express')
const app = express()

const log = (req,res,next) => {
  const ip = req.ip,
     route = req.route.path
  const log = `ip:${ip} path:${route}`
   fs.writeFileSync(__dirname + '/log',log)
   next()
}

app.use(log)//任何請(qǐng)求都會(huì)經(jīng)過這個(gè)log中間件 

app.get('/', (req, res) => {
  console.log(req.route.stack)
  res.send('這是一個(gè)根路由!')
})

app.get('/router1', (req, res) => {
  res.send('這是一個(gè)router1路由!')
})
app.get('/router2', (req, res) => {
  res.send('這是一個(gè)router2路由!')
})


app.listen(3000, () => {
  console.log('app listening on port 3000!')
})
GET '/router2' //打印日志,并且返回結(jié)果

這就是一個(gè)簡單的中間件解釋了。大家也可以回去看看你原來寫過的代碼,是否對(duì)之前的use這個(gè)玩意有點(diǎn)啟發(fā)了?

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解nodejs模板引擎制作

    詳解nodejs模板引擎制作

    本篇文章主要介紹了nodejs模板引擎制作 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • 使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項(xiàng)目

    使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項(xiàng)目

    這篇文章主要介紹了使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項(xiàng)目的教程,自動(dòng)化構(gòu)建工具Grunt具有編譯壓縮單元測(cè)試等功能,十分強(qiáng)大,需要的朋友可以參考下
    2016-02-02
  • 深入理解nodejs中Express的中間件

    深入理解nodejs中Express的中間件

    一個(gè)Express應(yīng)用就是在調(diào)用各種中間件。可見中間件在web應(yīng)用開發(fā)中的重要性,有興趣的可以了解一下
    2017-05-05
  • npm?i報(bào)錯(cuò)以及解決方案實(shí)戰(zhàn)案例

    npm?i報(bào)錯(cuò)以及解決方案實(shí)戰(zhàn)案例

    npm在前端開發(fā)流程中提供了非常完善的自動(dòng)化工具鏈,但是同樣由于其復(fù)雜性導(dǎo)致有很多奇奇怪怪的問題,下面這篇文章主要給大家介紹了關(guān)于npm?i報(bào)錯(cuò)以及解決方案的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 基于node簡單實(shí)現(xiàn)RSA加解密的方法步驟

    基于node簡單實(shí)現(xiàn)RSA加解密的方法步驟

    這篇文章主要介紹了基于node簡單實(shí)現(xiàn)RSA加解密的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-03-03
  • node版本過高該如何將node版本降低

    node版本過高該如何將node版本降低

    我們常使用nvm來管理node.js的版本,這樣就可以根據(jù)自己的需要來回切換node.js版本,下面這篇文章主要給大家介紹了關(guān)于node版本過高該如何將node版本降低的相關(guān)資料,需要的朋友可以參考下
    2023-01-01
  • Express中使用Swagger的實(shí)現(xiàn)示例

    Express中使用Swagger的實(shí)現(xiàn)示例

    swagger-express是一個(gè)規(guī)范和完整的框架實(shí)現(xiàn),本文主要介紹了Express中使用Swagger的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-12-12
  • node.js文件的復(fù)制、創(chuàng)建文件夾等相關(guān)操作

    node.js文件的復(fù)制、創(chuàng)建文件夾等相關(guān)操作

    這篇文章主要給大家介紹了node.js文件的復(fù)制、創(chuàng)建文件夾等相關(guān)操作,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • nodejs發(fā)送http請(qǐng)求時(shí)遇到404長時(shí)間未響應(yīng)的解決方法

    nodejs發(fā)送http請(qǐng)求時(shí)遇到404長時(shí)間未響應(yīng)的解決方法

    這篇文章主要為大家詳細(xì)介紹了nodejs發(fā)送http請(qǐng)求時(shí)遇到404長時(shí)間未響應(yīng)的解決方法
    2017-12-12
  • node連接kafka2.0實(shí)現(xiàn)方法示例

    node連接kafka2.0實(shí)現(xiàn)方法示例

    這篇文章主要介紹了node連接kafka2.0,nodejs連接kafka2.0的實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了kafka2.0的功能、原理、以及node.js連接kafka2.0的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2023-05-05

最新評(píng)論