国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

Python 基于jwt實現認證機制流程解析

瀏覽:101日期:2022-07-20 08:00:19

1.jwt的優缺點

jwt的優點:

1. 實現分布式的單點登陸非常方便

2. 數據實際保存在客戶端,所以我們可以分擔數據庫或服務器的存儲壓力

jwt的缺點:

1. 數據保存在了客戶端,我們服務端只認jwt,不識別客戶端。2. jwt可以設置過期時間,但是因為數據保存在了客戶端,所以對于過期時間不好調整。

2.安裝jwt

pip install djangorestframework-jwt -i https://pypi.douban.com/simple

3.在settings.dev中

REST_FRAMEWORK = { ’DEFAULT_AUTHENTICATION_CLASSES’: ( ’rest_framework_jwt.authentication.JSONWebTokenAuthentication’, ’rest_framework.authentication.SessionAuthentication’, ’rest_framework.authentication.BasicAuthentication’, ),}import datetimeJWT_AUTH = { ’JWT_EXPIRATION_DELTA’: datetime.timedelta(days=1), ##設置token的有效值}

4.手動生成jwt

from rest_framework_jwt.settings import api_settingsjwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLERjwt_encode_handler = api_settings.JWT_ENCODE_HANDLERpayload = jwt_payload_handler(user)token = jwt_encode_handler(payload)

5.后端實現登陸認證接口(在子應用路由urls.py中)

from rest_framework_jwt.views import obtain_jwt_tokenurlpatterns = [ path(r’login/’, obtain_jwt_token), ##提供接口]

6.自定義返回數據,(user.utils.jwt_response_payload_handler路徑下)

def jwt_response_payload_handler(token, user=None, request=None): ''' 自定義jwt認證成功返回數據 ''' return { ’token’: token, ’id’: user.id, ’username’: user.username }#這個是自定義jwt認證成功返回數據,一般會放在子應用下utils文件中,然后在settings中配置,將路徑告訴django

7.修改settings.dev配置文件

# JWTJWT_AUTH = { ’JWT_EXPIRATION_DELTA’: datetime.timedelta(days=1), ’JWT_RESPONSE_PAYLOAD_HANDLER’: ’user.utils.jwt_response_payload_handler’,}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 泸溪县| 武川县| 洛隆县| 焉耆| 教育| 肇东市| 萝北县| 伊通| 洪江市| 湾仔区| 夏河县| 孝昌县| 云霄县| 黄大仙区| 皋兰县| 竹北市| 瓦房店市| 德保县| 常山县| 沛县| 烟台市| 全椒县| 九台市| 彭阳县| 德格县| 丰城市| 花莲县| 汉寿县| 北流市| 建瓯市| 彭山县| 奈曼旗| 施秉县| 阿勒泰市| 偏关县| 长葛市| 罗江县| 永年县| 亳州市| 西峡县| 南城县|