1、安装Simple-JWT插件
pip install djangorestframework-simplejwt
2、配置主模块配置 settings.py
添加 rest_framework_simplejwt 和 rest_framework_simplejwt.token_blacklist 到 INSTALLED_APPS :
INSTALLED_APPS = [
"django.contrib.admin",
"django.contrib.auth",
"django.contrib.contenttypes",
"django.contrib.sessions",
"django.contrib.messages",
"django.contrib.staticfiles",
"rest_framework",
"app_drf01.apps.AppDrf01Config",
"api.apps.ApiConfig",
"rest_framework_simplejwt",
]
3、配置 REST_FRAMEWORK
在 settings.py 文件中,配置 DEFAULT_AUTHENTICATION_CLASSES ,添加 JWTAuthentication 。
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework_simplejwt.authentication.JWTAuthentication',
),
}
4、settings.py完整代码
from pathlib import Path
import os# Build paths inside the project like this: BASE_DIR / 'subdir'.
BASE_DIR = Path(__file__).resolve().parent.parent
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = "django-insecure-ws(9g7m^dty#ouzqdii*s^((+a33v@qn654gm0+b)_97)#sx-e"
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definitionINSTALLED_APPS = ["django.contrib.admin","django.contrib.auth","django.contrib.contenttypes","django.contrib.sessions","django.contrib.messages","django.contrib.staticfiles","rest_framework","app_drf01.apps.AppDrf01Config","api.apps.ApiConfig","rest_framework_simplejwt",
]REST_FRAMEWORK = {"DEFAULT_AUTHENTICATION_CLASSES": ("rest_framework_simplejwt.authentication.JWTAuthentication",)
}MIDDLEWARE = ["django.middleware.security.SecurityMiddleware","django.contrib.sessions.middleware.SessionMiddleware","django.middleware.common.CommonMiddleware","django.middleware.csrf.CsrfViewMiddleware","django.contrib.auth.middleware.AuthenticationMiddleware","django.contrib.messages.middleware.MessageMiddleware","django.middleware.clickjacking.XFrameOptionsMiddleware",
]ROOT_URLCONF = "maker_drf.urls"
TEMPLATES = [{"BACKEND": "django.template.backends.django.DjangoTemplates","DIRS": [],"APP_DIRS": True,"OPTIONS": {"context_processors": ["django.template.context_processors.debug","django.template.context_processors.request","django.contrib.auth.context_processors.auth","django.contrib.messages.context_processors.messages",],},},
]WSGI_APPLICATION = "maker_drf.wsgi.application"
DATABASES = {"default": {"ENGINE": "django.db.backends.mysql","NAME": "python_demo", # 数据库名称"USER": "root", # 数据库用户名"PASSWORD": "1234567890", # 数据库密码"HOST": "127.0.0.1", # 数据库主机地址"PORT": "13306", # 数据库端口}
}AUTH_PASSWORD_VALIDATORS = [{"NAME": "django.contrib.auth.password_validation.UserAttributeSimilarityValidator",},{"NAME": "django.contrib.auth.password_validation.MinimumLengthValidator",},{"NAME": "django.contrib.auth.password_validation.CommonPasswordValidator",},{"NAME": "django.contrib.auth.password_validation.NumericPasswordValidator",},
]# 设置默认语言为中文
LANGUAGE_CODE = "zh-hans" # 简体中文# 设置默认时区
TIME_ZONE = "Asia/Shanghai" # 上海时区USE_I18N = TrueUSE_TZ = TrueSTATIC_URL = "static/"DEFAULT_AUTO_FIELD = "django.db.models.BigAutoField"# 媒体文件的存储路径
MEDIA_ROOT = os.path.join(BASE_DIR, "media")# 媒体文件的访问 URL
MEDIA_URL = "/media/"from datetime import timedeltaSIMPLE_JWT = {"ACCESS_TOKEN_LIFETIME": timedelta(minutes=5), # Access Token 的有效期"REFRESH_TOKEN_LIFETIME": timedelta(days=7), # Refresh Token 的有效期"ROTATE_REFRESH_TOKENS": True, # 刷新时是否生成新的 Refresh Token"BLACKLIST_AFTER_ROTATION": True, # 是否在刷新后废弃旧的 Refresh Token"ALGORITHM": "HS256", # 使用的加密算法"SIGNING_KEY": SECRET_KEY, # 设置签名密钥"VERIFYING_KEY": None, # 如果使用公钥算法,可以配置验证密钥
}
5、 主urls.py配置(和上一版的是一样)
from django.contrib import admin
from django.urls import path, include, re_path
from django.views.static import serve
from django.conf import settings
from app_drf01 import viewsurlpatterns = [path("admin/", admin.site.urls),re_path(r"^media/(?P<path>.*)$",serve,{"document_root": settings.MEDIA_ROOT},name="media",),path("test/", views.test),path("api/", include(("api.urls", "api"), namespace="api")),
]
6、api模块中的urls.py配置
urlpatterns = [
# 登录
path("token/", TokenObtainPairView.as_view(), name="token_obtain_pair"),
# 刷新
path("token/refresh/", TokenRefreshView.as_view(), name="token_refresh"),
# 校验
path("token/verify/", TokenVerifyView.as_view(), name="token_verify"),
]
完整配置如下:
from django.urls import path, re_path
from . import viewsfrom rest_framework import routers
from rest_framework_simplejwt.views import (TokenObtainPairView,TokenRefreshView,TokenVerifyView,TokenBlacklistView,
)routers = routers.DefaultRouter()
routers.register("linkapi", views.Linkapi)app_name = "api"
urlpatterns = [# 登录path("token/", TokenObtainPairView.as_view(), name="token_obtain_pair"),# 刷新path("token/refresh/", TokenRefreshView.as_view(), name="token_refresh"),# 校验path("token/verify/", TokenVerifyView.as_view(), name="token_verify"),# 黑名单path("token/blacklist/", TokenBlacklistView.as_view(), name="token_blacklist"),
]urlpatterns += routers.urls
7、创建一个用户,执行命令
python manage.py createsuperuser
按照提示去创建用户信息
基于apifox工具去测试以下内容:
8、模拟登录,获取token
http://127.0.0.1:8000/api/token/ POST
{
"username": "admin",
"password": "23232"
}
9、 刷新,获取token
http://127.0.0.1:8000/api/token/refresh/ POST
{
"refresh": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ0b2tlbl90eXBlIjoicmVmcmVzaCIsImV4cCI6MTc0Mzk5MjAwMywiaWF0IjoxNzQzMzg3MjAzLCJqdGkiOiI0ZmU5YWQ3N2E3Y2E0NDA1YjkzNWE0M2Y2ZDlkOWYxMiIsInVzZXJfaWQiOjF9.MsKXMsV3E34233Z0wpOqroMAmOLHzBi-pYf5mFcNtFg"
}
10、 校验token
http://127.0.0.1:8000/api/token/verify/ POST
11、查询接口测试
12、 新增接口
需要先配置token,否则数据提交失败。
配置token到apifox中的auth窗口
13、基于自动化脚本去设置环境变量
在login接口去配置
var jsonData = pm.response.json()
pm.environment.set("refresh_token", jsonData.refresh);
pm.environment.set("access_token", jsonData.access);
14、测试 更新接口
从环境变量中选择对应的token
15、执行更新url操作成功
16、全局配置,点击父目录进行以上同样的配置
备注:如果配置的未生效,需要将当前的tab页关掉,重新打开就可以访问。
17、代码下载
链接: https://pan.baidu.com/s/1BD6WLdL_1OHKUl1cPhykPw?pwd=rt1w 提取码: rt1w