Python Flask token身份認(rèn)證的示例代碼(附完整代碼)
前言
Python Flask是一個使用Python編寫的輕量級Web應(yīng)用框架,它可以非常方便地搭建Web應(yīng)用。在Web應(yīng)用中,經(jīng)常需要進(jìn)行身份認(rèn)證,以確保只有授權(quán)用戶才能訪問某些資源。本文將介紹如何使用token進(jìn)行身份認(rèn)證,以及如何在Python Flask中實(shí)現(xiàn)token身份認(rèn)證。
一、什么是token身份認(rèn)證
token身份認(rèn)證(Token-based authentication)是一種常見的Web身份認(rèn)證方式,它是利用token來確保用戶的身份。每個用戶在登錄后都會得到一個token,通過該token來識別用戶的身份,這種方式可以減少服務(wù)器的負(fù)擔(dān),提高身份認(rèn)證的效率。在使用token身份認(rèn)證時,用戶成功登錄后,服務(wù)器會生成一個token,將該token發(fā)送給客戶端??蛻舳嗽诤罄m(xù)的請求中,需要在請求頭中攜帶該token,以便服務(wù)器可以識別用戶的身份。服務(wù)器接收到請求后,會從token中解析出用戶的身份信息,并對該用戶進(jìn)行身份認(rèn)證。
二、如何實(shí)現(xiàn)token身份認(rèn)證
在Python Flask中,實(shí)現(xiàn)token身份認(rèn)證需要以下步驟:
1、安裝所需的依賴
flask flask_jwt_extended
可以使用pip命令來安裝:
pip install flask pip install flask_jwt_extended
2、創(chuàng)建一個Flask應(yīng)用
在Python代碼中引用flask庫,并創(chuàng)建一個Flask應(yīng)用:
from flask import Flask app = Flask(__name__)
3、配置密鑰
需要在Flask應(yīng)用中配置一個密鑰secret_key,用于生成token和驗證token的有效性??梢栽贔lask應(yīng)用中添加如下代碼:
app.config['JWT_SECRET_KEY'] = 'my_secret_key'
其中,'my_secret_key'可以替換成其他隨機(jī)字符串。
4、創(chuàng)建用戶登錄接口
在Flask應(yīng)用中,需要創(chuàng)建一個接口,用于用戶登錄,用戶輸入正確的用戶名和密碼后,生成一個token,返回給客戶端??梢栽贔lask應(yīng)用中添加如下代碼:
from flask import request, jsonify from flask_jwt_extended import create_access_token @app.route('/login', methods=['POST']) def login(): username = request.json.get('username', None) password = request.json.get('password', None) if username != 'admin' or password != 'admin': return jsonify({"msg": "Bad username or password"}), 401 access_token = create_access_token(identity=username) return jsonify(access_token=access_token), 200
其中,'/login'是接口路徑,使用POST方法,接收用戶名和密碼。如果用戶名或密碼錯誤,則返回401狀態(tài)碼和錯誤提示。如果用戶名和密碼正確,則使用create_access_token方法生成一個token,該token的有效期默認(rèn)設(shè)置為15分鐘。
5、創(chuàng)建需要身份認(rèn)證的接口
在Flask應(yīng)用中,有些接口需要進(jìn)行身份認(rèn)證才能訪問,可以使用@jwt_required裝飾器來實(shí)現(xiàn)。可以在Flask應(yīng)用中添加如下代碼:
from flask_jwt_extended import jwt_required, get_jwt_identity @app.route('/protected', methods=['GET']) @jwt_required() def protected(): current_user = get_jwt_identity() return jsonify(logged_in_as=current_user), 200
其中,'/protected'是需要身份認(rèn)證的接口路徑,使用GET方法。使用@jwt_required裝飾器來表示需要進(jìn)行token身份認(rèn)證。在接口中,可以使用get_jwt_identity()方法獲取當(dāng)前用戶的身份信息。
6、啟動Flask應(yīng)用
在Python代碼中添加如下代碼,啟動Flask應(yīng)用:
if __name__ == '__main__': app.run(debug=True)
三、完整代碼示例
from flask import Flask, request, jsonify from flask_jwt_extended import create_access_token, jwt_required, get_jwt_identity app = Flask(__name__) app.config['JWT_SECRET_KEY'] = 'my_secret_key' @app.route('/login', methods=['POST']) def login(): username = request.json.get('username', None) password = request.json.get('password', None) if username != 'admin' or password != 'admin': return jsonify({"msg": "Bad username or password"}), 401 access_token = create_access_token(identity=username) return jsonify(access_token=access_token), 200 @app.route('/protected', methods=['GET']) @jwt_required() def protected(): current_user = get_jwt_identity() return jsonify(logged_in_as=current_user), 200 if __name__ == '__main__': app.run(debug=True)
四、總結(jié)
本文介紹了如何在Python Flask中使用token進(jìn)行身份認(rèn)證。通過以上步驟,可以快速地搭建一個基于token的身份認(rèn)證系統(tǒng)。在實(shí)際應(yīng)用中,還需要考慮如何管理token的有效性、token的過期時間等問題。
到此這篇關(guān)于Python Flask token身份認(rèn)證的示例代碼(附完整代碼)的文章就介紹到這了,更多相關(guān)Flask token身份認(rèn)證內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python?NumPy教程之?dāng)?shù)組的基本操作詳解
Numpy?中的數(shù)組是一個元素表(通常是數(shù)字),所有元素類型相同,由正整數(shù)元組索引。本文將通過一些示例詳細(xì)講一下NumPy中數(shù)組的一些基本操作,需要的可以參考一下2022-08-08Python Web框架之Django框架Model基礎(chǔ)詳解
這篇文章主要介紹了Python Web框架之Django框架Model基礎(chǔ),結(jié)合實(shí)例形式分析了Django框架Model模型相關(guān)使用技巧與操作注意事項,需要的朋友可以參考下2019-08-08Python析構(gòu)函數(shù)__del__定義原理解析
這篇文章主要介紹了Python析構(gòu)函數(shù)__del__定義原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11Python實(shí)現(xiàn)雙因素驗證2FA的示例代碼
雙因素認(rèn)證(2FA)作為額外安全層為賬號登錄添加了第二層身份驗證。確保賬號持有人是可以訪問數(shù)字身份的唯-用戶。如果不使用雙因表認(rèn)證,企業(yè)將承擔(dān)巨大的安全風(fēng)險。本文將用Python實(shí)現(xiàn)雙因素驗證2FA,需要的可以參考一下2022-07-07使用Python在Word文檔中添加,刪除和回復(fù)批注
在文檔協(xié)作與審閱場景中,高效管理批注是提升團(tuán)隊效率的關(guān)鍵環(huán)節(jié),下面我們就來看看如何使用Python在Word文檔中實(shí)現(xiàn)添加、刪除和回復(fù)批注的操作吧2025-03-03可視化工具PyVista多線程顯示多窗口的實(shí)例代碼
這篇文章主要介紹了可視化工具PyVista多線程顯示多窗口,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04