成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Python JWT 介紹和使用詳解

瀏覽:6日期:2022-06-20 08:30:39
1. JWT 介紹

​jwt( JSON Web Tokens ),是一種開發的行業標準 RFC 7519 ,用于安全的表示雙方之間的聲明。目前,jwt廣泛應用在系統的用戶認證方面,特別是現在前后端分離項目​jwt認證流程:

Python JWT 介紹和使用詳解

​在項目開發中,一般會按照上圖所示的過程進行認證,即:用戶登錄成功之后,服務端給用戶瀏覽器返回一個 token,以后用戶瀏覽器要攜帶 token 再去向服務端發送請求,服務端校驗 token 的合法性,合法則給用戶看數據,否則,返回一些錯誤信息

​傳統token方式和jwt在認證方面有什么差異?

傳統 token 方式:用戶登錄成功后,服務端生成一個隨機 token 給用戶,并且在服務端(數據庫或緩存)中保存一份 token,以后用戶再來訪問時需攜帶 token,服務端接收到 token 之后,去數據庫或緩存中進行校驗 token 的是否超時、是否合法 jwt 方式:用戶登錄成功后,服務端通過 jwt 生成一個隨機 token 給用戶(服務端無需保留 token),以后用戶再來訪問時需攜帶token,服務端接收到 token 之后,通過 jwt 對 token 進行校驗是否超時、是否合法2. JWT 創建 token2.1 JWT 生成原理

jwt 的生成 token 格式如下,即:由 . 連接的三段字符串組成

eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c

生成規則如下:

第一段 HEADER 部分,固定包含算法和 token 類型,對此 json 進行 base64url 加密,這就是 token的第一段

{'alg': 'HS256','typ': 'JWT'}

第二段 PAYLOAD 部分,包含一些數據,對此json進行base64url加密,這就是token的第二段

{'sub': '1234567890','name': 'John Doe','iat': 1516239022...}

第三段 SIGNATURE 部分,把前兩段的 base64url 密文通過. 拼接起來,然后對其進行 HS256 加密,再然后對hs256 密文進行 base64url 加密,最終得到 token 的第三段

base64url(HMACSHA256(base64UrlEncode(header) + '.' + base64UrlEncode(payload),your-256-bit-secret (秘鑰加鹽)))

​最后將三段字符串通過 . 拼接起來就生成了 jwt 的 token

​注意:base64url 加密是先做 base64 加密,然后再將 - 替代 + 及 _ 替代 /

2.2 JWT 校驗 token 原理

​一般在認證成功后,把 jwt 生成的 token 返回給用戶,以后用戶再次訪問時候需要攜帶 token,此時 jwt 需要對token 進行超時及合法性校驗​獲取 token 之后,會按照以下步驟進行校驗:

將token分割成 header_segment 、payload_segment 、crypto_segment 三部分

JWT_TOKEN ='eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c'signing_input, crypto_segment = JWT_TOKEN.rsplit(’.’, 1)header_segment, payload_segment = signing_input.split(’.’, 1)

對第一部分header_segment 進行 base64url 解密,得到 header

對第二部分payload_segment 進行 base64url 解密,得到 payload

對第三部分crypto_segment 進行 base64url 解密,得到 signature,針對 signature 部分數據進行合法性校驗

拼接前兩段密文,即:signing_input 從第一段明文中獲取加密算法,默認:HS256 使用算法+鹽 對 signing_input 進行加密,將得到的結果和 signature 密文進行比較3. 代碼實現

​基于 Python 的 pyjwt 模塊創建 jwt 的 token

安裝

pip3 install pyjwt

實現

from datetime import datetime, timedeltaimport jwtclass JwtToken(object): _salt = '@^4_00wedv**pi)+(!w1rwi=d3q4l=ie=g-u$s8jevmj*zgg2h' _expire_message = dict(code=1200, msg='token 已經失效') _unknown_error_message = dict(code=4200, msg='token 解析失敗') @classmethod def generate_token(cls, payload: dict) -> str:headers = dict(typ='jwt', alg='HS256')resut = jwt.encode(payload=payload, key=cls._salt, algorithm='HS256', headers=headers)return resut @classmethod def parse_token(cls, token: str) -> tuple:verify_status = Falsetry: payload_data = jwt.decode(token, cls._salt, algorithms=[’HS256’]) verify_status = Trueexcept jwt.ExpiredSignatureError: payload_data = cls._expire_messageexcept Exception as _err: payload_data = cls._unknown_error_messagereturn verify_status, payload_dataif __name__ == ’__main__’: TEST_DATA = dict(name='mooor', exp=datetime.utcnow() - timedelta(seconds=1)) token = JwtToken.generate_token(TEST_DATA) print(token) payload = JwtToken.parse_token(token) print(payload)

​注意:exp 務必選擇 UTC 時間

Expiration time will be compared to the current UTC time (as given by timegm(datetime.utcnow().utctimetuple())), so be sure to use a UTC timestamp or datetime in encoding

4. 參數介紹4.1 示例:

import jwtimport datetimedic = { ’exp’: datetime.datetime.utcnow() + datetime.timedelta(days=1), # 過期時間 ’iat’: datetime.datetime.utcnow(), # 開始時間 ’iss’: ’ChaosMoor’, # 簽名 ’data’: { # 內容,一般存放該用戶id和開始時間’a’: 1,’b’: 2, },}token = jwt.encode(dic, ’secret’, algorithm=’HS256’) # 加密生成字符串print(token)payload = jwt.decode(token, ’secret’, issuer=’lianzong’, algorithms=[’HS256’]) # 解密,校驗簽名print(s)print(type(s))

​dic 有官方指定的 key,程序在解密的時候會根據 key 的 Value 判斷是否合法。這些 key 有:

'exp':在生成 token 時,可以設置該 token 的有效時間,如果我們設置 1 天過期,1 天后我們再解析此 token 會拋出

jwt.exceptions.ExpiredSignatureError: Signature has expired

'nbf':它指的是該 token 的生效時間,如果使用但是沒到生效時間則拋出:

jwt.exceptions.ImmatureSignatureError: The token is not yet valid (nbf)

'iss': token 的簽發者,我們可以給他一個字符串,注意,iss 在接收時如果不檢驗也沒有問題,如果我們接收時需要檢驗但是又簽名不一致,則會拋出

jwt.exceptions.InvalidIssuerError: Invalid issuer

'aud':指定了接收者,接收者在接收時必須提供與 token 要求的一致的接收者(字符串),如果沒寫接收者或者接收者不一致會拋出

jwt.exceptions.InvalidAudienceError: Invalid audience

'iat':token 的開始時間,如果當前時間在開始時間之前則拋出

jwt.exceptions.InvalidIssuedAtError: Issued At claim (iat) cannot be in the future.

4.2 PyJWT 官方文檔

https://pyjwt.readthedocs.io/en/latest/usage.html

Python JWT 介紹和使用詳解

到此這篇關于Python JWT 介紹和使用詳解的文章就介紹到這了,更多相關Python JWT使用內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲一区二区三区精品在线观看| 亚洲国产精品麻豆| 成人免费视频一区| 天天射综合影视| 国产精品丝袜91| 在线成人免费观看| 亚洲一区bb| 国内一区二区在线视频观看| 极品美女销魂一区二区三区| 亚洲图片欧美视频| 91精品国产欧美一区二区| 99re66热这里只有精品4| 精品一区二区av| 天堂资源在线中文精品| 国产精品女主播在线观看| 欧美电视剧免费全集观看| 91国模大尺度私拍在线视频| 亚洲精品一级| 国产在线成人| 欧美精品99| av综合在线播放| 国产成人午夜精品5599| 人人狠狠综合久久亚洲| 久久久午夜精品| 日韩欧美国产麻豆| 在线免费亚洲电影| 蜜乳av另类精品一区二区| 狠狠色综合网| 亚洲经典自拍| 红杏aⅴ成人免费视频| 国产综合亚洲精品一区二| 99re热视频这里只精品| a亚洲天堂av| 欧美69视频| 亚洲第一在线| 日韩午夜免费| 国产欧美一区二区三区国产幕精品| 亚洲午夜精品久久久久久app| 欧美日本国产精品| 在线视频观看日韩| 你懂的亚洲视频| 亚洲国产精品成人综合| 欧美区在线观看| 久久奇米777| 精品人伦一区二区色婷婷| 欧美一二区视频| 日韩一区在线看| 狠狠色狠狠色综合日日91app| a亚洲天堂av| 免费在线亚洲欧美| 欧美精品一区二区三区四区| 亚洲综合一区在线| 不卡的电视剧免费网站有什么| 黄色日韩在线| 欧美人妖巨大在线| 中文字幕中文字幕在线一区| 久久99精品久久久久| 国语精品一区| 欧美日韩一区视频| 亚洲黄色小说网站| 91网址在线看| 777久久久精品| 亚洲电影视频在线| 国产主播一区| 日韩免费视频一区| 日本vs亚洲vs韩国一区三区 | 久久中文在线| 日韩一区二区免费高清| 久久综合九色综合久久久精品综合| 亚洲丶国产丶欧美一区二区三区| 欧美~级网站不卡| 日韩一二在线观看| 天天综合天天做天天综合| 欧美视频网站| 久久久久99精品一区| 国产精品一卡二| 影音欧美亚洲| 久久久国产午夜精品| 精油按摩中文字幕久久| 欧美美女一区二区在线观看| 一区二区成人在线观看| 成人高清视频免费观看| 欧美三级中文字幕在线观看| 夜夜嗨av一区二区三区| 欧美精品日本| 久久久久久久久久久久久久久99| 日本vs亚洲vs韩国一区三区| 日韩一级欧洲| 国产精品久久二区二区| 欧美福利一区| 精品av综合导航| 国产一区二区三区四区五区入口| 亚洲综合99| 久久精品日产第一区二区三区高清版| 国产aⅴ综合色| 欧美一级片免费看| 免费在线观看一区| 久久男女视频| 日韩avvvv在线播放| 久久黄色影院| 视频精品一区二区| 久久九九电影| 一区二区三区丝袜| 丰满亚洲少妇av| 国产精品电影院| 欧美一级专区| 日韩精品乱码免费| 欧美精品tushy高清| 美女视频网站久久| 在线欧美日韩精品| 国产精品你懂的在线欣赏| 波多野结衣亚洲一区| 久久精子c满五个校花| 91麻豆国产精品久久| 国产精品第一页第二页第三页| 欧美午夜电影在线观看| 中文字幕日韩精品一区| 国产一区二区调教| 日韩一区二区视频| 欧美成人tv| 中文字幕视频一区二区三区久| 亚洲精品日韩久久| 97超碰欧美中文字幕| 中文字幕一区二区三区色视频| 99热这里只有成人精品国产| 亚洲国产sm捆绑调教视频| 久久精品日产第一区二区三区| 男人操女人的视频在线观看欧美| 亚洲人成影院在线观看| 亚洲一区二区三区四区中文| 喷水一区二区三区| 精品成人免费观看| 午夜在线播放视频欧美| 国产精品 欧美精品| 久久久久久久久久看片| 成人午夜电影网站| 亚洲一级片在线观看| 亚洲精品一区二区三区香蕉| 久久综合激情| 一色屋精品视频在线看| 国产呦精品一区二区三区网站| 91黄视频在线| 色综合天天综合| 视频一区视频二区中文字幕| 日韩一级片网址| 亚洲精品影视| 高清久久久久久| 91精品在线免费| 亚洲国产一区二区三区| 欧美电影一区二区三区| 国语自产精品视频在线看抢先版结局| 日本成人中文字幕在线视频 | 欧美亚洲一区三区| 国产精品一级在线| 中文字幕综合网| 欧美日韩一区三区四区| 亚洲成av人片一区二区三区| 亚洲国产高清一区二区三区| 欧美人与禽性xxxxx杂性| 亚洲成人动漫在线免费观看| 精品国产三级a在线观看| 久久婷婷色综合| 欧美日韩影院| 麻豆一区二区在线| 亚洲高清不卡在线观看| 日韩精品一区二区在线| 欧美日韩国产免费| 在线免费一区三区| 亚洲伊人观看| 一本色道久久综合亚洲精品不卡 | 久久久噜噜噜久久中文字幕色伊伊| 国产精品一区二区你懂得| 欧美大片免费久久精品三p | 成人免费视频播放| 国产日韩一区二区三区在线播放| 欧美一区二区观看视频| 人人超碰91尤物精品国产| 亚洲国内在线| 欧美不卡一区二区三区| 国产一区美女在线| 色噜噜狠狠色综合中国| 日韩精品国产精品| 91电影在线观看| 狠狠色综合色综合网络| 欧美三级一区二区| 懂色av一区二区三区蜜臀| 欧美无乱码久久久免费午夜一区 | 人人狠狠综合久久亚洲| 在线观看一区| 国产精品久99| 国产综合第一页| 91成人在线精品| 日韩精品欧美精品| 国产精品视频| 日韩和欧美一区二区| 国产真实乱子伦精品视频| 久久99精品国产麻豆不卡| 国产一区二区三区美女| 菠萝蜜视频在线观看一区| 91在线精品一区二区三区|