您的位置:首页 > 科技 > 能源 > 画网页_青岛建设集团股份有限公司_网站建设开发公司_seo线下培训班

画网页_青岛建设集团股份有限公司_网站建设开发公司_seo线下培训班

2025/7/3 7:24:28 来源:https://blog.csdn.net/zsb706496992/article/details/146606518  浏览:    关键词:画网页_青岛建设集团股份有限公司_网站建设开发公司_seo线下培训班
画网页_青岛建设集团股份有限公司_网站建设开发公司_seo线下培训班

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 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com