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

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

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

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

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 前端必知:接口安全你了解多少?

前端必知:接口安全你了解多少?

來源:千鋒教育
發(fā)布人:syq
時(shí)間: 2022-07-14 16:02:00 1657785720

  前后端分離式開發(fā)需要進(jìn)行數(shù)據(jù)交互,傳輸?shù)臄?shù)據(jù)被偷窺、被抓包、被偽造時(shí)有發(fā)生,那么如何設(shè)計(jì)一套比較安全的API接口方案呢?

  并不是所有的接口都需要考慮安全的,有些接口是公開的,任何人只要知道地址都可以調(diào)用,對(duì)于一些項(xiàng)目中需要用戶登錄才能訪問的接口才需要考慮安全問題。

  一般解決的方案有以下幾類:

  token令牌認(rèn)證(jwt)

  AK(app key)&SK(secret key)【用戶名&密碼】

  時(shí)間戳超時(shí)驗(yàn)證+簽名算法字符串

  URL簽名(算法,非對(duì)稱算法)

  數(shù)據(jù)脫敏(防范數(shù)據(jù)庫數(shù)據(jù)泄露)

  HTTPS

  IP黑/白名單(服務(wù)器層面的限制,apache、nginx)

  oAuth2.0

  關(guān)于JWT:

  Json web token(JWT),是基于token的鑒權(quán)機(jī)制,類似于http協(xié)議也是無狀態(tài)的,它不需要在服務(wù)端去保留用戶的認(rèn)證信息或者會(huì)話信息,為應(yīng)用的擴(kuò)展提供了便利。JWT具備以下幾個(gè)優(yōu)點(diǎn):

  因json的通用性,所以JWT是可以進(jìn)行跨語言

  JWT可以在自身存儲(chǔ)一些其他業(yè)務(wù)邏輯所必要的非敏感信息

  便于傳輸,jwt的構(gòu)成非常簡(jiǎn)單,字節(jié)占用很小,所以它是非常便于傳輸?shù)?/p>

  它不需要在服務(wù)端保存會(huì)話信息,所以它非常適合應(yīng)用在前后端分離的項(xiàng)目上

  使用JWT進(jìn)行鑒權(quán)的工作流程如下(重點(diǎn)):

  用戶使用用戶名密碼來請(qǐng)求服務(wù)器

  服務(wù)器進(jìn)行驗(yàn)證用戶的信息(查數(shù)據(jù)庫)

  服務(wù)器通過驗(yàn)證發(fā)送給用戶一個(gè)token(令牌)

  客戶端存儲(chǔ)token(Vuex+localStorage),并在每次請(qǐng)求時(shí)附送上這個(gè)token值

  服務(wù)端驗(yàn)證token值,并返回?cái)?shù)據(jù)

11

  JWT是由三段信息構(gòu)成的(頭部、載荷、簽名),將這三部分使用.連接在一起就組成了JWT字符串,形如:

22

  其中:

  · 頭部(header),包含了兩(可以更多)部分信息,分別是類型的聲明和所使用的加密算法。

  一個(gè)完整的頭部就像下面的JSON:

{

  'typ': 'JWT',

  'alg': 'HS256'

}

  然后將頭部進(jìn)行base64加密/編碼(該加密是可以對(duì)稱解密的),這就得到了jwt的第一部分。

  · 載荷(payload)(body),載荷就是存放有效信息的地方。這些有效信息包含三個(gè)部分

  o 標(biāo)準(zhǔn)中約定聲明(建議但不強(qiáng)制)

  § 簽發(fā)人

  § 使用者

  § 簽發(fā)時(shí)間

  § 有效期

  § ....

  o 公共的聲明

  o 私有的聲明

  定義一個(gè)payload:

{

  "sub": "1234567890",

  "name": "John Doe",

  "admin": true

}

  依舊進(jìn)行base64加密,這就得到了jwt的第二部分。

  · 簽名(signature),這個(gè)簽證信息由三部分組成:

經(jīng)過base64編碼后的

§ header

§ payload

secret

  例如:

var encodedString = base64UrlEncode(header) + '.' + base64UrlEncode(payload);

var signature = HMACSHA256(encodedString, 'secret');

  這樣就得到了jwt的第三部分。

var jwt = encodedString + '.' + base64UrlEncode(signature);

  最終將三部分信息通過.進(jìn)行連接就得到了最終的jwt字符串。后續(xù)不需要自己去寫jwt怎么生成的。因此,此流程理解即可。

  需要注意的是

  · secret是保存在服務(wù)器端的

  · jwt的簽發(fā)生成也是在服務(wù)器端的

  · secret是用來進(jìn)行jwt的簽發(fā)和jwt的驗(yàn)證

  所以,secret它就是服務(wù)端的私鑰,在任何場(chǎng)景都不應(yīng)該泄露出去。一旦其他人(包括客戶端的用戶)得知這個(gè)secret,那就意味著他們可以自我簽發(fā)jwt,接口就沒有安全性可言了。

  更多關(guān)于“前端培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學(xué),課程大綱緊跟企業(yè)需求,更科學(xué)更嚴(yán)謹(jǐn),每年培養(yǎng)泛IT人才近2萬人。不論你是零基礎(chǔ)還是想提升,都可以找到適合的班型,千鋒教育隨時(shí)歡迎你來試聽。

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

PlatformIO是什么PlatformIO是一個(gè)全面的物聯(lián)網(wǎng)開發(fā)平臺(tái),它為眾多硬件平臺(tái)和開發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡(jiǎn)化了開發(fā)過程,并能兼容各種...詳情>>

2023-10-14 12:55:06
云快照與自動(dòng)備份有什么區(qū)別?

1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時(shí)間點(diǎn)后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動(dòng)備份的主要目標(biāo)...詳情>>

2023-10-14 12:48:59
服務(wù)器為什么要用Linux?

服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢(shì)和特點(diǎn)。包括其...詳情>>

2023-10-14 12:34:11
ORM解決的主要問題是什么?

ORM(對(duì)象關(guān)系映射)解決的主要問題是將關(guān)系數(shù)據(jù)庫與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫中,數(shù)據(jù)以表格的形式存儲(chǔ),而在面向?qū)ο?..詳情>>

2023-10-14 12:26:19
Go為什么不支持三元運(yùn)算符?

Go為什么不支持三元運(yùn)算符Go語言是一種以簡(jiǎn)潔和有效性為目標(biāo)的編程語言,因此在設(shè)計(jì)過程中,Go的設(shè)計(jì)者刻意排除了一些他們認(rèn)為可能導(dǎo)致復(fù)雜性或...詳情>>

2023-10-14 12:12:36