久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術(shù)干貨  > 創(chuàng)建身份驗證服務(wù)器并在后端應(yīng)用程序中使用它

創(chuàng)建身份驗證服務(wù)器并在后端應(yīng)用程序中使用它

來源:千鋒教育
發(fā)布人:syq
時間: 2022-09-15 11:16:59 1663211819

  今天,我們將討論如何創(chuàng)建一個僅用于管理身份驗證請求的隔離環(huán)境,以及如何有效地將其添加為中間件以保護API。

創(chuàng)建身份驗證服務(wù)器

  我們將遵循的一般想法是,首先,我們將創(chuàng)建一個常規(guī)服務(wù)器,該服務(wù)器將具有一個簡單的請求,并且我們需要保護它,因此我們將創(chuàng)建一個中間件來接收標頭并確保我們擁有正確的訪問權(quán)限。我們還將使用API_KEY身份驗證來防止內(nèi)部使用?,F(xiàn)在你有了基本的想法,所以讓我們開始吧。

  為什么我們需要身份驗證服務(wù)器?

  您可能想知道為什么我們需要一個身份驗證服務(wù)器,難道我們不能只在一臺服務(wù)器中處理嗎?顯然,您可以,但是當您的應(yīng)用程序開始增長時,您可能需要將整體式應(yīng)用程序轉(zhuǎn)移到微服務(wù)級別,此策略將幫助您解決問題。

  設(shè)計身份驗證服務(wù)器

  我們將保持簡單。在我們的身份驗證中,我們不會查看源或網(wǎng)關(guān),而只會查看身份驗證令牌和 API 密鑰。首先,我創(chuàng)建了一個示例 Express App,其中我們剛剛導入了路由,并在存在解析器的情況下使用了默認錯誤處理。

介紹417

  快速應(yīng)用程序

  甚至身份驗證服務(wù)器也需要保護,因此我們還將定義一個中間件規(guī)則來保護它。對于此示例,我使用的API_KEY但您也可以創(chuàng)建 oAuth 或基本身份驗證。為了使用它,我創(chuàng)建了一個文件,里面有一個中間件,它將檢查API_KEY,如果使用虛擬數(shù)據(jù)源出現(xiàn)任何問題,則會拋出錯誤。

介紹881

  接口密鑰中間件

  在這里,我們使用我們的虛擬數(shù)據(jù)源檢查API KEYS是否存在且有效,如果情況失敗,則拋出錯誤,否則從路由調(diào)用下一個控制器

  現(xiàn)在,我們有一個中間件設(shè)置,我們實際上可以從API開發(fā)開始。我們將僅創(chuàng)建2條路線,但您可以根據(jù)需要創(chuàng)建任意數(shù)量的路線

  登錄

  驗證

  我已經(jīng)創(chuàng)建了一個實用程序文件,該文件將創(chuàng)建或驗證令牌,以便我們可以直接使用控制器中的方法。我正在使用軟件包來生成或驗證,但您可以使用您喜歡的軟件包jsonwebtoken

介紹1103

  Jwt 實用程序函數(shù)

  在這里,我們只使用和方法,但理想情況下,您還應(yīng)該使用方法使您的應(yīng)用程序為過期的令牌做好準備,然后該過程signverifydecode

  從現(xiàn)在開始,我們已經(jīng)設(shè)置了所有內(nèi)容,讓我們創(chuàng)建路由

介紹1210

  路線

  在這里,我們導入了所有依賴項,并創(chuàng)建了登錄和驗證的路由。在 login API 中,您可以執(zhí)行任何與數(shù)據(jù)庫相關(guān)的操作,然后有條件地生成令牌,但在此示例中,我跳過了該部分并直接從 發(fā)送令牌。另一方面,為了驗證,我們獲取授權(quán)標頭,然后使用方法來驗證令牌是否有效。req.body.payloadverifyToken

  如果一切正常,那么在運行服務(wù)器和API后,我們將收到以下輸出:

介紹1404

  就是這樣,我們的身份驗證服務(wù)器已準備好響應(yīng)。下一步是在任何其他微服務(wù)應(yīng)用程序中使用此服務(wù)

  使用身份驗證服務(wù)

  要使用我們剛剛創(chuàng)建的身份驗證服務(wù),我們需要使用 HTTP 請求提供程序。我要使用Axios,但您可以選擇您選擇的任何提供商

  我寫了一篇文章,它將幫助我們創(chuàng)建和使外部API調(diào)用更加敏捷。以下是本文的鏈接,我建議您也閱讀有關(guān)此內(nèi)容的信息。

  如何處理公理和節(jié)點J中的不同端點

  為 Axios 創(chuàng)建基于類的實例并有效使用它們。

  javascript.plainenglish.io

  服務(wù)生成器

  我們將首先創(chuàng)建一個生成器類,該類將處理所有請求的邏輯:api_key

介紹1855

  身份驗證服務(wù)生成器

  在這里,我們創(chuàng)建了一個類,該類將API_KEY作為構(gòu)造函數(shù)參數(shù)。此類將創(chuàng)建一個具有標頭和標頭中的 axios 實例,并設(shè)置為任何 API 的超時。除了屬性之外,我們還將公開將調(diào)用我們?yōu)樯矸蒡炞C服務(wù)創(chuàng)建的 API 的方法。baseURL api_key 10000ms login verify

  除了生成器之外,我們還將創(chuàng)建一個文件,該文件將創(chuàng)建此類的實例并向我們公開該方法:index.js

介紹2059

  實例創(chuàng)建

  就是這樣,我們有一個將與auth服務(wù)交互的類,并將負責管理更改單例。

  創(chuàng)建驗證中間件

  現(xiàn)在,我們已經(jīng)有了服務(wù)。下一步是創(chuàng)建一個中間件,為我們處理驗證:

介紹2142

  身份驗證服務(wù)中間件

  在這里,我們創(chuàng)建了一個中間件,它將從req對象中提取標頭并將其傳遞給我們之前創(chuàng)建的方法。verify

  創(chuàng)建路由

  該過程的最后一步是創(chuàng)建路由并使用中間件。首先,我們需要導入我們創(chuàng)建的中間件,然后在任何測試路線上使用它。通過的情況下,所有未經(jīng)授權(quán)的請求都將被阻止,只有授權(quán)的請求才能訪問API。

介紹2300

  創(chuàng)建路線

  要測試此 API,我們需要傳遞在 API 上獲得的授權(quán)令牌,并將其傳入此處。我們不需要通過,因為它對服務(wù)級別有限制。loginapi_key

介紹2378

  失敗案例場景

  如果我們沒有傳遞令牌或傳遞格式錯誤的令牌,則會導致未經(jīng)授權(quán)的請求。

介紹2421

  通過案例場景

  微服務(wù)架構(gòu)的傳遞案例場景

  我們?yōu)槲⒎?wù)創(chuàng)建了 2 個服務(wù)體系結(jié)構(gòu),但您可以增加服務(wù)以使用身份驗證服務(wù),它將在復制處理程序時完美運行。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
抖店入駐收費多少?開抖店費用是多少?

如果要開通抖音小店,需要先把抖音賬號開通商品櫥窗功能。入駐之后,可以選擇頭條賬號、抖音賬號、火山賬號任一類型注冊或登錄。那開個抖店要多...詳情>>

2023-09-19 07:50:26
想做直播帶貨的貨源哪里來?怎么找貨源?

現(xiàn)如今直播推廣的方式是非?;鸬模兄浅6嗟馁u家都是利用直播推廣店鋪產(chǎn)品,效果也是非常不錯。但很多賣家想要了解現(xiàn)在直播帶貨的話什么產(chǎn)品...詳情>>

2023-09-19 07:47:16
適合三農(nóng)領(lǐng)域的名字?有何技巧?

現(xiàn)在在抖音上很多博主會選擇直播來賺取更多的流量以及利潤,直播間的東西也有很多讓消費者信任并且喜歡的,而且隨著越來越多人直播,很多農(nóng)產(chǎn)品...詳情>>

2023-09-19 07:06:05
抖店商品發(fā)布違規(guī)怎么申訴?有何規(guī)則?

抖店服務(wù)市場服務(wù)商發(fā)布違禁信息如何處理?情節(jié)嚴重程度判定原則:違規(guī)嚴重等級主要通過服務(wù)商違規(guī)次數(shù)、造成后果的嚴重程度、獲利或?qū)е聯(lián)p失的...詳情>>

2023-09-19 06:59:55
“泛垂直起號”可能是2023年最高效的起號方式

這可能是明年最好用的旗號方式了,今天教大家一個很野,但是可以讓你三天漲1000粉的偏方。去年前年啊,每個人都教你,誰知七號對著自己的產(chǎn)品拍...詳情>>

2023-09-19 06:37:38
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)