中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

simple JWT身份驗證怎么在DRF項目中使用

發布時間:2021-01-14 16:12:40 來源:億速云 閱讀:666 作者:Leah 欄目:開發技術

這篇文章給大家介紹simple JWT身份驗證怎么在DRF項目中使用,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

登錄返回token和refresh

user 模型類:

我user模型類繼承的是django.contrib.auth.models.AbstractUser,這樣可以使用Django自帶的認證。

如果繼承該類,我們就必須在settings中配置 AUTH_USER_MODEL = "users.UserProfile"

from datetime import datetime

from django.db import models
from django.contrib.auth.models import AbstractUser
# Create your models here.

class UserProfile(AbstractUser):
  """
  用戶
  """
  name = models.CharField(max_length=30, null=True, blank=True, verbose_name="姓名")
  birthday = models.DateField(null=True, blank=True, verbose_name="出生年月")
  gender = models.CharField(max_length=6, choices=(("male", u"男"), ("female", "女")), default="female", verbose_name="性別")
  mobile = models.CharField(null=True, blank=True, max_length=11, verbose_name="電話")
  email = models.CharField(max_length=100, null=True, blank=True, verbose_name="郵箱")

  class Meta:
    verbose_name = "用戶"
    verbose_name_plural = "用戶"

  def __str__(self):
    return self.username

序列化文件:

注意這里使用的User是Django管理的user模型類,要從django.contrib.auth.get_user_model實例化獲取。

users模塊的serializers.py文件中寫如下序列化類繼承自rest_framework_simplejwt.serializers.TokenObtainPairSerializer

simple JWT身份驗證怎么在DRF項目中使用

from django.contrib.auth import get_user_model
User = get_user_model()

class MyTokenObtainPairSerializer(TokenObtainPairSerializer):
  @classmethod
  def get_token(cls, user):
    token = super().get_token(user)
    token['name'] = user.username
    return token

  def validate(self, attrs):
    """
    登錄返回token和refresh
    :param attrs:
    :return:
    """
    data = super().validate(attrs)
    data['token'] = str(data["access"])
    return data

根據官方文檔的說明,get_token方法之所以設置token['name']是因為程序可能運行在集群上,這里不寫也可以。

編寫視圖類

from users.serializers import MyTokenObtainPairSerializer

class MyTokenObtainPairView(TokenObtainPairView):
  serializer_class = MyTokenObtainPairSerializer

編寫url:

其中api/token/api/token/refresh/兩個URL是simple JWT自帶的token方法:

  • api/token/用于獲取token

  • api/token/refresh/用于刷新token

from django.conf.urls import url
from django.urls import include, path

from rest_framework_simplejwt.views import (
  TokenObtainPairView,
  TokenRefreshView,
)

urlpatterns = [
  # simple jwt 認證接口
  path('api/token/', TokenObtainPairView.as_view(), name='token_obtain_pair'),
  path('api/token/refresh/', TokenRefreshView.as_view(), name='token_refresh'),
  path('login/', MyTokenObtainPairView.as_view(), name='token_obtain_pair'),
]

settings配置SIMPLE_JWT:

這是對token的一些自定義設置包括獲取的token和refresh的生命周期等配置,通過查看rest_framework_simplejwt的源碼可以發現有很多自定義配置,感興趣的小伙伴可以通過查看官方文檔了解更多,這里我只配置了獲取的token的生命周期。

啟動程序訪問:

simple JWT身份驗證怎么在DRF項目中使用

simple JWT身份驗證怎么在DRF項目中使用

可以發現返回了三個值:

  • refresh:是刷新token用的,當前端token過期需要刷新token的時候就可以訪問前邊說的api/token/refreshurl,參數就是refresh的值。

  • access:這個就是token但是框架里叫做access。

  • token:這個是在序列化文件中給access新命名了一個值,方便前端獲取:

def validate(self, attrs):
  """
  登錄返回token和refresh
  :param attrs:
  :return:
  """
  data = super().validate(attrs)
  data['token'] = str(data["access"])
  return data

注冊返回token

視圖類:

  • 在視圖類中導入from rest_framework_simplejwt.tokens import RefreshToken

  • 重寫create方法,需要通過前邊導入的RefreshToken來獲取token返回給前端。

from django.contrib.auth import get_user_model
from django.db.models import Q
from rest_framework.response import Response
from rest_framework_simplejwt.tokens import RefreshToken
from rest_framework.mixins import CreateModelMixin
from rest_framework import viewsets
from rest_framework import status

from users.serializers import (
  UserRegSerializer
)
from .models import VerifyCode

User = get_user_model()


class UserViewSet(CreateModelMixin, viewsets.GenericViewSet):
  """
  用戶
  """
  serializer_class = UserRegSerializer
  queryset = User.objects.all()

  def create(self, request, *args, **kwargs):
    serializer = self.get_serializer(data=request.data)
    serializer.is_valid(raise_exception=True)
    user = self.perform_create(serializer)

    ret_dict = serializer.data
    refresh = RefreshToken.for_user(user)
    access_token = str(refresh.access_token)
    ret_dict["token"] = access_token

    headers = self.get_success_headers(serializer.data)
    return Response(ret_dict, status=status.HTTP_201_CREATED, headers=headers)

  def perform_create(self, serializer):
    return serializer.save()

關于simple JWT身份驗證怎么在DRF項目中使用就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

二连浩特市| 兰西县| 舞钢市| 报价| 阳高县| 鄂托克旗| 南溪县| 奎屯市| 昌平区| 苏尼特右旗| 元谋县| 定边县| 桐庐县| 安溪县| 余庆县| 西贡区| 乌兰察布市| 项城市| 公安县| 滨海县| 霍邱县| 嘉义市| 县级市| 台湾省| 乃东县| 东丰县| 拜城县| 磐石市| 秭归县| 喀喇沁旗| 乐东| 博乐市| 邵武市| 罗田县| 昌图县| 肃北| 松潘县| 湖口县| 大化| 承德县| 河北省|