前后分离token的方式做登录身份校验,jwt校验方式更加简单便捷化,无需通过redis缓存,而是直接根据token取出保存的用户信息,以及对token可用性校验,单点登录更为简单。

配置环境:
python 3.7
Django==2.1.11
djangorestframework-jwt==1.10.0
pip install djangorestframework-jwt
1.打开项目中settings.py配置

import datetime
# drf框架的配置信息
REST_FRAMEWORK = {
    # 设置所有接口都需要被验证
    'DEFAULT_PERMISSION_CLASSES': (
        #’rest_framework.permissions.IsAuthenticatedOrReadOnly’,
    # 用户登陆认证方式
    'DEFAULT_AUTHENTICATION_CLASSES': (
        ‘rest_framework_jwt.authentication.JSONWebTokenAuthentication’,
        #’rest_framework.authentication.SessionAuthentication’,
        #’rest_framework.authentication.BasicAuthentication’,
# jwt载荷中的有效期设置
JWT_AUTH = {
    #token 有效期
    'JWT_EXPIRATION_DELTA': datetime.timedelta(hours=8),
    'JWT_ALLOW_REFRESH': True,
     #续期有效期(该设置可在24小时内带未失效的token 进行续期) 
    'JWT_REFRESH_EXPIRATION_DELTA': datetime.timedelta(hours=24),
    # 自定义返回格式,需要手工创建
    'JWT_RESPONSE_PAYLOAD_HANDLER': ‘Users.utils.jwt_response_payload_handler’,

2.创建自定义返回数据格式

# 创建用户应用
python manage.py startapp Users

在Users应用目录下新建utils.py 并配置文件

自定义jwt认证成功返回数据 :token 返回的jwt :user 当前登录的用户信息[对象] :request 当前本次客户端提交过来的数据 :role 角色 def jwt_response_payload_handler(token, user=None, request=None, role=None): if user.first_name: name = user.first_name else: name = user.username return { "authenticated": ‘true’, 'id': user.id, "role": role, 'name': name, 'username': user.username, 'email': user.email, 'token': token,
  • 申请token
    1.打开项目中urls.py 配置路由
  • from django.contrib import admin
    from django.urls import path, include
    urlpatterns = [
        path('admin/', admin.site.urls),
        path('users/', include('Users.urls’)),
    

    2.在Users应用目录下创建并打开urls.py

    # jwt内部实现的登陆视图
    from rest_framework_jwt.views import obtain_jwt_token, refresh_jwt_token
    from django.urls import path
    urlpatterns = [
        path(r"login", obtain_jwt_token),
    

    3.打开postman,调用登录接口传入username和password获取token

  • token 续期
    在Users应用目录下打开urls.py
  • # jwt内部实现的登陆视图
    from rest_framework_jwt.views import obtain_jwt_token, refresh_jwt_token
    from django.urls import path
    urlpatterns = [
        path(r"login", obtain_jwt_token),
        path(r"refresh", refresh_jwt_token),
    验证的时候,我们使用的是rest_framework 框架,该框架使用将在其他文档详细叙述。

    permission是权限验证 IsAuthenticated必须登录用户 IsOwnerOrReadOnly必须是当前登录的用户

    from rest_framework.permissions import IsAuthenticated,IsAuthenticatedOrReadOnly
    """分页配置"""
    class LargeResultsSetPagination(PageNumberPagination):
        page_size = 10
        page_size_query_param = 'page_size'
        max_page_size = 10000
    """域名列表"""
    class DomainManageList(viewsets.ReadOnlyModelViewSet):
        # authentication是用户认证
        authentication_classes = (JSONWebTokenAuthentication,)
        # permission是权限验证 IsAuthenticated必须登录用户 IsOwnerOrReadOnly必须是当前登录的用户
        # permission_classes = (IsAuthenticated, IsOwnerOrReadOnly)
        #判断是否登陆
        permission_classes = (IsAuthenticated, )
        #查询所有信息
        queryset = Domain_Manage.objects.all()
        serializer_class = DomainManageListSerializers
        pagination_class = LargeResultsSetPagination