drf simplejwt自定义认证方式

1.TokenViewBase调用TokenObtainSerializer里面的validate()方法

class TokenViewBase(generics.GenericAPIView):
  def post(self, request: Request, *args, **kwargs) -> Response:
    serializer = self.get_serializer(data=request.data) 
    try:
        serializer.is_valid(raise_exception=True)# 调用serializer.validate()
    except TokenError as e:
        raise InvalidToken(e.args[0])
    return Response(serializer.validated_data, status=status.HTTP_200_OK)
2.调用from django.contrib.auth import authenticate 里面的认证方法

class TokenObtainSerializer(serializers.Srializer):
    def validate(self, attrs: Dict[str, Any]) -> Dict[Any, Any]:
        authenticate_kwargs = { # 获取用户名和密码
            self.username_field: attrs[self.username_field],
            "password": attrs["password"],
        }
        try:
            authenticate_kwargs["request"] = self.context["request"]
        except KeyError:
            pass
        self.user = authenticate(**authenticate_kwargs) #调用认证方法
        return {}

    @classmethod
    def get_token(cls, user: AuthUser) -> Token:
        return cls.token_class.for_user(user)  # type: ignore

3. 拉取settings.py里面配置的AUTHENTICATION_BACKENDS:认证类,并调用里面的authenticate()方法

def authenticate(request=None, **credentials):
    for backend, backend_path in _get_backends(return_tuples=True): 
        try:
            user = backend.authenticate(request, **credentials) 
        except PermissionDenied:
            break
        if user is None:
            continue
        user.backend = backend_path
        return user
def _get_backends(return_tuples=False):
    backends = []
    for backend_path in settings.AUTHENTICATION_BACKENDS:
        backend = load_backend(backend_path)
        backends.append((backend, backend_path) if return_tuples else backend)
    if not backends:
        raise ImproperlyConfigured(
            "No authentication backends have been defined. Does "
            "AUTHENTICATION_BACKENDS contain anything?"
        )
    return backends

ModelBackend里面有一个authenicate方法也可以选择复写其他类里面得authnicate方法

from django.contrib.auth.backends import ModelBackend
def authenticate(self, request, username=None, password=None, **kwargs):
    if username is None:
        username = kwargs.get(UserModel.USERNAME_FIELD)
    if username is None or password is None:
        return
    try:
        user = UserModel._default_manager.get_by_natural_key(username)
    except UserModel.DoesNotExist:
        # Run the default password hasher once to reduce the timing
        # difference between an existing and a nonexistent user (#20760).
        UserModel().set_password(password)
    else:
        if user.check_password(password) and self.user_can_authenticate(user):
            return user
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值