用故事的講述 JWT

用講故事的方法講述 JWT

JWT 就像一張門禁卡

小明管理著一個(gè)小區(qū)的物業(yè),負(fù)責(zé)整個(gè)小區(qū)的出入安全。剛開始的時(shí)候小明決定要保險(xiǎn)一點(diǎn),所有出入小區(qū)的都要驗(yàn)證業(yè)主的本人信息块请。

所以他搞了個(gè)規(guī)定,每個(gè)進(jìn)小區(qū)的人都要驗(yàn)證身份證和指紋拳缠,通過后臺(tái)證明你是業(yè)主才讓你進(jìn)去墩新。剛開始的時(shí)候這個(gè)規(guī)定還行,但是隨著小區(qū)的出入人員變多窟坐,處理速度太慢海渊,小區(qū)業(yè)主經(jīng)常需要排隊(duì)進(jìn)入小區(qū)。

收到了大量的投訴電話只后小明決定反思一下哲鸳,決定使用門禁卡來解決這個(gè)效率問題臣疑。他于是讓業(yè)主去物業(yè)做一個(gè)一次性的身份驗(yàn)證,通過了之后就發(fā)一張門禁卡給業(yè)主徙菠,不過門禁卡有期限限制讯沈,半年之后就需要更新一下,而且業(yè)主刷卡的時(shí)候懒豹,物業(yè)只需要驗(yàn)證下這是不是我們發(fā)的業(yè)主卡就行了芙盘。

物業(yè)在處理門禁卡信息的時(shí)候,會(huì)從門禁卡里面解密信息脸秽,那個(gè)信息里面帶有業(yè)主自己本人的信息儒老。

在這個(gè)故事里面,

  • 第一個(gè)的每次進(jìn)入小區(qū)都需要驗(yàn)證就是傳統(tǒng)的session登錄方法
  • 門禁卡制度就是jwt

用python實(shí)踐 JWT

使用JWT實(shí)踐的方法很簡單记餐,就是分三部分驮樊。

  • 服務(wù)器驗(yàn)證是否是用戶
  • 服務(wù)器為用戶生成一個(gè)TOKEN
  • 用戶訪問服務(wù)器的時(shí)候帶著那個(gè)TOKEN
  • 服務(wù)驗(yàn)證TOKEN是否合法
  • 用戶訪問內(nèi)容

完整的例子

from flask import Flask, jsonify, request
from flask_jwt_extended import (
    JWTManager, jwt_required, create_access_token,
    get_jwt_identity
)

app = Flask(__name__)

# Setup the Flask-JWT-Extended extension
app.config['JWT_SECRET_KEY'] = 'super-secret'  # Change this!
jwt = JWTManager(app)


# Provide a method to create access tokens. The create_access_token()
# function is used to actually generate the token, and you can return
# it to the caller however you choose.
@app.route('/login', methods=['POST'])
def login():
    if not request.is_json:
        return jsonify({"msg": "Missing JSON in request"}), 400

    username = request.json.get('username', None)
    password = request.json.get('password', None)
    if not username:
        return jsonify({"msg": "Missing username parameter"}), 400
    if not password:
        return jsonify({"msg": "Missing password parameter"}), 400

    if username != 'test' or password != 'test':
        return jsonify({"msg": "Bad username or password"}), 401

    # Identity can be any data that is json serializable
    # 服務(wù)器為用戶生成一個(gè)TOKEN
    access_token = create_access_token(identity=username)
    return jsonify(access_token=access_token), 200


# Protect a view with jwt_required, which requires a valid access token
# in the request to access.
@app.route('/protected', methods=['GET'])
@jwt_required
def protected():
    # Access the identity of the current user with get_jwt_identity
    # 服務(wù)驗(yàn)證TOKEN是否合法
    current_user = get_jwt_identity()
    # 用戶訪問內(nèi)容
    return jsonify(logged_in_as=current_user), 200


if __name__ == '__main__':
    app.run()

運(yùn)行該程序

  • 用戶如何獲得token
curl -H "Content-Type: application/json" -X POST \
  -d '{"username":"test","password":"test"}' http://localhost:5000/login

代碼會(huì)返回類似于

{"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmcmVzaCI6dHJ1ZSwianRpIjoiZjhmNDlmMjUtNTQ4OS00NmRjLTkyOWUtZTU2Y2QxOGZhNzRlIiwidXNlcl9jbGFpbXMiOnt9LCJuYmYiOjE0NzQ0NzQ3OTEsImlhdCI6MTQ3NDQ3NDc5MSwiaWRlbnRpdHkiOiJ0ZXN0IiwiZXhwIjoxNDc0NDc1NjkxLCJ0eXBlIjoiYWNjZXNzIn0.vCy0Sec61i9prcGIRRCbG8e9NV6_wFH2ICFgUGCLKpc"}

  • 用戶訪問的過程中帶上token
export ACCESS="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmcmVzaCI6dHJ1ZSwianRpIjoiZjhmNDlmMjUtNTQ4OS00NmRjLTkyOWUtZTU2Y2QxOGZhNzRlIiwidXNlcl9jbGFpbXMiOnt9LCJuYmYiOjE0NzQ0NzQ3OTEsImlhdCI6MTQ3NDQ3NDc5MSwiaWRlbnRpdHkiOiJ0ZXN0IiwiZXhwIjoxNDc0NDc1NjkxLCJ0eXBlIjoiYWNjZXNzIn0.vCy0Sec61i9prcGIRRCbG8e9NV6_wFH2ICFgUGCLKpc"

然后訪問接口

curl -H "Authorization: Bearer $ACCESS" http://localhost:5000/protected

最后返回

{
  "logged_in_as": "test"
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市片酝,隨后出現(xiàn)的幾起案子囚衔,更是在濱河造成了極大的恐慌,老刑警劉巖雕沿,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件练湿,死亡現(xiàn)場離奇詭異,居然都是意外死亡审轮,警方通過查閱死者的電腦和手機(jī)肥哎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來疾渣,“玉大人篡诽,你說我怎么就攤上這事×窦瘢” “怎么了杈女?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我达椰,道長翰蠢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任砰碴,我火速辦了婚禮躏筏,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘呈枉。我一直安慰自己,他們只是感情好埃碱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布猖辫。 她就那樣靜靜地躺著,像睡著了一般砚殿。 火紅的嫁衣襯著肌膚如雪啃憎。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天似炎,我揣著相機(jī)與錄音辛萍,去河邊找鬼。 笑死羡藐,一個(gè)胖子當(dāng)著我的面吹牛贩毕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播仆嗦,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼辉阶,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瘩扼?” 一聲冷哼從身側(cè)響起谆甜,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎集绰,沒想到半個(gè)月后规辱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡栽燕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年罕袋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纫谅。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡炫贤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出付秕,到底是詐尸還是另有隱情兰珍,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布询吴,位于F島的核電站掠河,受9級(jí)特大地震影響亮元,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唠摹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一爆捞、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧勾拉,春花似錦煮甥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至斧蜕,卻和暖如春双霍,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背批销。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國打工洒闸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人均芽。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓丘逸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親骡技。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鸣个,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 各鎮(zhèn)人民政府,開發(fā)區(qū)布朦、茅山旅游度假區(qū)管委會(huì)囤萤,東城街道辦事處,市各委辦局是趴,市直各單位: 《金壇市物業(yè)管理辦法》已經(jīng)市...
    我愛灬我家閱讀 1,822評(píng)論 0 1
  • 首先聲明涛舍,我只是一個(gè)平時(shí)喜歡關(guān)注小區(qū)事關(guān)自身利益大小事、對(duì)南都物業(yè)服務(wù)不滿而拒絕交納物業(yè)費(fèi)的普通業(yè)主唆途,而非1富雅、2、...
    cncity2017閱讀 1,554評(píng)論 0 2
  • 時(shí)間很快肛搬,快到我總感覺自己在虛度没佑,沒有一點(diǎn)點(diǎn)成長的每天,讓我對(duì)未來充滿了膽怯温赔。焦慮和不安占據(jù)我心理的大部分蛤奢,連身體...
    木易大膽閱讀 165評(píng)論 0 0
  • 案例一~四:記憶撲克四組 總結(jié): 撲克轉(zhuǎn)換數(shù)字還是有些慢了,連結(jié)的也不是特別緊密,jqk的轉(zhuǎn)換老是卡頓啤贩。 主要還是...
    文魁大腦彭文浩閱讀 128評(píng)論 0 1
  • 事物皆有兩面性待秃,對(duì)錯(cuò)也好,利弊也罷痹屹。至少看事物的方向不一樣了章郁,味道也就變了。
    生活過敏閱讀 251評(píng)論 1 4