欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 人文社科 > 生活经验 >内容正文

生活经验

「Django」rest_framework学习系列-用户认证

发布时间:2023/11/27 生活经验 62 豆豆
生活随笔 收集整理的这篇文章主要介绍了 「Django」rest_framework学习系列-用户认证 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

用户认证:
1.项目下utils文件写auth.py文件

from rest_framework import exceptions
from api import models
from rest_framework.authentication import BaseAuthentication
#还有4个类可以继承
class BasicAuthentication(BaseAuthentication)  可以弹出登录框
class SessionAuthentication(BaseAuthentication):
class TokenAuthentication(BaseAuthentication):
class RemoteUserAuthentication(BaseAuthentication):class Authtication(BaseAuthentication):#用户认证类def authenticate(self,request):#源码方法重写token = request._request.GET.get('token')token_obj = models.UserToken.objects.filter(token=token).first()if not token_obj:raise exceptions.AuthenticationFailed('用户认证失败')#在rest framework内部会将这两个字段赋值给request,以供后续使用return (token_obj.user,token_obj)#认证失败之后返回给浏览器的请求头def authenticate_header(self,request):pass

 

2、settings配置用户全局认证如下:

'DEFAULT_AUTHENTICATION_CLASSES':['api.utils.auth.Authtication',], #用户全局认证

3.views业务类可以在全局认证外设置单独认证规则

authentication_classes = [] #已设置全局认证,此处即空认证

4.源码认证流程图

 

5.匿名用户全局配置:

 
REST_FRAMEWORK = {'UNAUTHENTICATED_USER':None, #匿名,request.user = None 

'UNAUTHENTICATED_TOKEN':None, #匿名,request.auth = None }

转载于:https://www.cnblogs.com/wrxblog/p/10400106.html

总结

以上是生活随笔为你收集整理的「Django」rest_framework学习系列-用户认证的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。