在线不卡日本ⅴ一区v二区_精品一区二区中文字幕_天堂v在线视频_亚洲五月天婷婷中文网站

  • <menu id="lky3g"></menu>
  • <style id="lky3g"></style>
    <pre id="lky3g"><tt id="lky3g"></tt></pre>

    七爪源碼:讓我們了解 Express.js 中的中間件

    七爪源碼:讓我們了解 Express.js 中的中間件

    Express.js 中的中間件概念簡單有趣的介紹

    如果你已經(jīng)在 Node.js 周圍呆了足夠長的時(shí)間,你可能已經(jīng)聽說過中間件,我不會撒謊,當(dāng)我第一次遇到 WORD ITSELF 時(shí)我很困惑所以更不用說中間件的實(shí)現(xiàn)了,但是你’必須動手學(xué)習(xí)所以請?jiān)试S我輕輕地教你關(guān)于中間件需要了解的知識 盡可能簡單

    建立我們的開發(fā)環(huán)境

    如果您使用的是 Linux 或 Mac,請打開您的終端,如果您使用的是 Windows,請打開命令提示符

    mkdir 中間件 && cd 中間件創(chuàng)建一個(gè)新目錄并導(dǎo)航到它

    npm init –y 使用默認(rèn)設(shè)置初始化一個(gè)新的 npm 項(xiàng)目(稍后你可以使用 package.json,我將向你展示)

    npm i express && npm i –save-dev nodemon 這將首先安裝 express,因?yàn)槲覀冃枰鼇順?gòu)建我們的后端,然后我們將安裝 nodemon 并將其保存為 dev 依賴項(xiàng),因?yàn)槲覀儗?shí)際上并不需要它生產(chǎn)環(huán)境

    向 package.json 添加腳本

    如果你打開你的 package.json 文件,你會發(fā)現(xiàn)一個(gè)名為 scripts 的部分,這個(gè)部分包含在終端中運(yùn)行命令的“快捷方式”,它非常有用,所以讓我們添加一個(gè)小腳本來運(yùn)行 nodemon,看起來就像我們在太酷了

    “dev”: “nodemon index.js” 在“test”腳本之后添加這個(gè)

    要觸發(fā)這些腳本,我們只需在終端輸入 npm run 后跟腳本部分中定義的腳本名稱,因此在我們的例子中,我們輸入 npm run dev 但讓我們稍后再使用它:)

    無論如何,什么是中間件

    中間件基本上是在路由處理函數(shù)之前執(zhí)行的函數(shù)……。 ik 這不是那么簡單所以讓我們來看看一個(gè)非常基本的快遞服務(wù)器

    const express = require(“express”);const app = express();app.get(“”, (req, res) => res.send(“you’ve reached the home page”));app.get(“/users”, (req, res) => res.send(“this is the users page”));app.get(“/articles”, (req, res) => res.send(“this is the articles page”));app.get(“*”, (req, res) => res.status(404).send(“Page not found”));app.listen(3000, () => console.log(“up and running”));

    好的,那里沒有什么太花哨的吧?我們有三個(gè)路由 / , /users , /articles 并且我們?yōu)檫@些路由中的每一個(gè)都有路由處理函數(shù)

    運(yùn)行 npm run dev ,您應(yīng)該會看到“啟動并運(yùn)行”的小消息

    我們的中間件將在對這些路由的每個(gè)請求之前或在特定路由之前執(zhí)行,因?yàn)槲覀兛梢赃x擇指定

    中間件基本上是一個(gè)可以訪問請求和響應(yīng)對象的功能,就像路由處理程序一樣,它可以用來記錄對我們服務(wù)器的每個(gè)請求或檢查用戶是否登錄,驗(yàn)證和授權(quán)用戶保護(hù)某些資源和許多其他目的

    中間件 VS。路由處理程序

    中間件和路由處理程序的最大區(qū)別是 next() 函數(shù)

    next() 函數(shù)是中間件的第三個(gè)參數(shù),它基本上告訴后端“繼續(xù)下一個(gè)中間件”,或者換句話說“給它綠燈繼續(xù)下一個(gè)例程”,所以我們的頁面不只是凍結(jié)并且永遠(yuǎn)不會完成加載,因此如果我們忘記放置它,程序?qū)o法繼續(xù),因?yàn)樗ㄔ谥虚g件中

    中間件的類型

    如上所述,我們有兩種類型的中間件,一種在應(yīng)用程序的頂層運(yùn)行,因此它像中間件一樣應(yīng)用于所有路由處理程序,以檢查用戶是否登錄,我們可以將其應(yīng)用于所有帖子路由我們正在編寫的一些社交媒體應(yīng)用程序

    默認(rèn) express 中間件的示例是 express.json() 中間件,我們一直在頂部使用它來啟用接受和解析 json

    另一種類型是在特定路由之前運(yùn)行的中間件,也許您需要保護(hù)某些可以訪問僅管理員文章或某些 VIP 內(nèi)容訪問權(quán)限的應(yīng)用程序的路由

    編寫我們的第一個(gè)中間件

    說了這么多,讓我們看看如何編寫我們自己的中間件,它會給我們一個(gè)美味的餅干

    在我們的導(dǎo)入之后添加這個(gè)代碼片段

    const say_hi = (req, res, next) => { console.log(“have a yummy cookie “); next();}

    為了在應(yīng)用級別“啟用”中間件,我們使用 express.use(say_hi); 并注意我們沒有添加括號,因?yàn)槲覀儧]有調(diào)用函數(shù)

    現(xiàn)在前往任何路線并檢查您的終端是否有

    你的 index.js 現(xiàn)在應(yīng)該是這樣的

    const express = require(“express”); const app = express(); const say_hi = (req, res, next) => { console.log(“have a yummy cookie “); next();};app.use(say_hi); app.get(“”, (req, res) => res.send(“you’ve reached the home page”)); app.get(“/users”, (req, res) => res.send(“this is the users page”)); app.get(“/articles”, (req, res) => res.send(“this is the articles page”)); app.get(“*”, (req, res) => res.status(404).send(“Page not found”)); app.listen(3000, () => console.log(“up and running”));

    為特定路線編寫中間件

    現(xiàn)在我們已經(jīng)了解了如何編寫一個(gè)在應(yīng)用程序級別運(yùn)行的中間件,也就是在每條路由之前運(yùn)行,讓我們再編寫兩個(gè)中間件,一個(gè)在用戶路由之前運(yùn)行,告訴我們“我愛我的用戶”,另一個(gè)用于文章 上面寫著“哇,看看所有這些文章”所以leggoooooo

    const users_middleware = (req, res, next) => { console.log(“i love my users “); next();};const articles_middleware = (req, res, next) => { console.log(“wow look at all those articles “);};

    現(xiàn)在,為了讓我們專門為我們的路由使用這些路由,我們需要分別將每個(gè)路由作為路由處理函數(shù)的參數(shù)傳遞,所以它現(xiàn)在看起來像這樣

    const express = require(“express”);const app = express();const say_hi = (req, res, next) => { console.log(“have a yummy cookie “); next();};app.use(say_hi);const users_middleware = (req, res, next) => { console.log(“i love my users “); next();};const articles_middleware = (req, res, next) => { console.log(“wow look at all those articles “); next();};app.get(“”, (req, res) => res.send(“you’ve reached the home page”));app.get(“/users”, users_middleware, (req, res) => res.send(“this is the users page”));app.get(“/articles”, articles_middleware, (req, res) => res.send(“this is the articles page”));app.get(“*”, (req, res) => res.status(404).send(“Page not found”));app.listen(3000, () => console.log(“up and running”));

    速記

    • 中間件只是一個(gè)函數(shù),在服務(wù)器接收到請求之后,在路由句柄響應(yīng)之前執(zhí)行
    • 他們可以訪問三個(gè)參數(shù),req res 和第三個(gè)參數(shù),這是一個(gè)方便地調(diào)用 next() 以允許下一個(gè)中間件運(yùn)行的函數(shù)
    • 它們可以在應(yīng)用程序級別,因此它們在對每個(gè)端點(diǎn)的每個(gè)請求之前運(yùn)行,或者可以指定到某個(gè)路由

    結(jié)論

    中間件一開始對于那些剛開始表達(dá)的人來說可能是一個(gè)復(fù)雜的概念,但是一旦你發(fā)現(xiàn)它們的真正需求,它們就很容易實(shí)現(xiàn),它們是一個(gè)強(qiáng)大的工具來調(diào)節(jié)你的服務(wù)器資源和訪問控制 許多其他需求,因?yàn)槟私馑鼈儽澈蟮幕舅枷?/p>

    非常感謝你能做到這一點(diǎn)我感謝你的時(shí)間和對我博客的興趣,我希望你喜歡你的白天/黑夜

    關(guān)注七爪網(wǎng),獲取更多APP/小程序/網(wǎng)站源碼資源!

    鄭重聲明:本文內(nèi)容及圖片均整理自互聯(lián)網(wǎng),不代表本站立場,版權(quán)歸原作者所有,如有侵權(quán)請聯(lián)系管理員(admin#wlmqw.com)刪除。
    用戶投稿
    上一篇 2022年6月19日 21:10
    下一篇 2022年6月19日 21:10

    相關(guān)推薦

    • ios手游模擬器(手游模擬器ios)

      本文主要講的是ios手游模擬器,以及和手游模擬器ios相關(guān)的知識,如果覺得本文對您有所幫助,不要忘了將本文分享給朋友。 哪個(gè)iOS模擬器能多開手游賬號?可以推薦個(gè)好用的模擬器給我嗎…

      2022年11月27日
    • 短視頻策劃內(nèi)容的3個(gè)要點(diǎn)(短視頻策劃內(nèi)容怎么做)

      短視頻在制作時(shí),內(nèi)容框架非常重要。如果直奔主題,然后結(jié)束,聚卓告訴你,這樣的短視頻已經(jīng)過時(shí)了?,F(xiàn)在的短視頻需要框架的,但不是任何框架,它需要一種易于理解和消化的框架。而且,現(xiàn)在大多…

      2022年11月27日
    • 美團(tuán)第三季度實(shí)現(xiàn)營收626億元,即時(shí)配送訂單量增至50億筆

      新京報(bào)訊(記者秦勝南)11月25日,美團(tuán)發(fā)布業(yè)績公告顯示,第三季度營收為626億元,較去年同比增長28.2%,凈利潤為12.2億元。第三季度,美團(tuán)即時(shí)配送訂單數(shù)增長至50億筆。截至…

      2022年11月27日
    • 存儲過程語法(sql server存儲過程語法)

      今天小編給各位分享存儲過程語法的知識,其中也會對sql server存儲過程語法進(jìn)行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關(guān)注本站,現(xiàn)在開始吧! oracle存儲過程基本語法…

      2022年11月26日
    • 個(gè)人怎么做抖音帶貨(個(gè)人做抖音帶貨能賺錢嗎)

      抖音如今是大家很熟悉的短視頻平臺,不過現(xiàn)在的抖音卻不只是短視頻那么簡單,它的功能非常豐富,其中一個(gè)就是可以帶貨,相信很多小伙伴都有在抖音上買過東西,抖音如今的變現(xiàn)能力也是不容小覷的…

      2022年11月25日
    • 小紅書平臺的一些機(jī)制及玩法詳解(小紅書玩法有哪些)

      關(guān)于小紅書 一:小紅書平臺的一些機(jī)制 1. 筆記內(nèi)容的CES評分機(jī)制 2. 筆記流量入口與長尾效應(yīng) 二:小紅書優(yōu)質(zhì)筆記的特點(diǎn)(分維度、類型分析) 1.筆記的本身架構(gòu)組成 維度 2.…

      2022年11月25日
    • 百度關(guān)鍵詞快速排名的4大原理解析(百度怎么刷關(guān)鍵詞)

      近期百度公告驚雷算法2.0,升級之快還是第一次吧,看來百度對于刷點(diǎn)擊行為是零容忍了。之前尹華峰SEO技術(shù)博客介紹過一篇如何使用刷點(diǎn)擊工具,其實(shí)市面上有很多這類SEO快速排名的軟件,…

      2022年11月25日
    • 直播帶貨詳細(xì)腳本(直播文案策劃怎么寫)

      短視頻運(yùn)營策劃方案怎么寫?涉及哪幾個(gè)方面? 我在網(wǎng)上看到好多千篇一律的文章,關(guān)于【短視頻運(yùn)營策劃方案】這一塊,基本都是在講賬號的內(nèi)容本身。 你內(nèi)容做得再好,卻不掌握算法的規(guī)律,能有…

      2022年11月25日
    • 銳龍97900x參數(shù)規(guī)格跑分評測 銳龍97900x屬于什么檔次

      銳龍9 7900X是銳龍7000系列處理器中性能頂尖的型號之一,它采用了這一代標(biāo)配的zen4架構(gòu)和5nm制程工藝,那么它具體的參數(shù)跑分如何,在電腦上世紀(jì)發(fā)揮怎么樣呢,下面就來看看銳…

      2022年11月24日
    • 今天出入濟(jì)南最新通知(出入濟(jì)南政策最新消息今天)

      近日濟(jì)南疫情感染人數(shù)也在不斷增加,劃分的高風(fēng)險(xiǎn)區(qū)也是越來越多了。據(jù)最新統(tǒng)計(jì),截止2022年11月24日11時(shí),濟(jì)南共有低風(fēng)險(xiǎn)地區(qū)12處,高風(fēng)險(xiǎn)地區(qū)338處。很多朋友都擔(dān)心現(xiàn)在濟(jì)南無…

      2022年11月24日

    聯(lián)系我們

    聯(lián)系郵箱:admin#wlmqw.com
    工作時(shí)間:周一至周五,10:30-18:30,節(jié)假日休息