工作原理
前台对于用户信息进行的判断
1)如果前台没有携带认证信息,直接定义为游客
2)如果前台携带了认证信息并认证通过,定位为登录用户,将登录的用户user对象保存在 requset.user 中
3)如果前台携带了认证信息但没有认证通过,一般都定义为游客
4 ) 可以自定义为非法用户,抛出 认证失败 异常,但是不建议直接 *** 作
,可以交给权限组件进一步处理rest_framework.exceptions 的 AuthenticationFailed
参数
BasicAuthentication : 基本认证
SessionAuthentication : session认证
2.权限工作原理
相关设置
即在我们自定义的视图类开头
设置
# 认证 下面不一定是[],也可以()就是需要在数组当中,多个类用,隔开# 局部取消认证组件:authentication_classes = []# 区别启用认证组件:authentication_classes = [认证类们] # 填写的参数BasicAuthentication,SessionAuthentication # 权限# 局部取消权限组件:permission_classes = []# 区别启用权限组件:permission_classes = [权限类们]# 填写的参数AllowAny
如
from rest_framework.authentication import SessionAuthentication,BasicAuthenticationfrom rest_framework.vIEws import APIVIEwfrom rest_framework.permissions import IsAuthenticated class 类名(APIVIEw): authentication_classes = (SessionAuthentication,BasicAuthentication) permission_classes = [IsAuthenticated,] ...........
三.全局设置在setting
中设置
REST_FRAMEWORK = { 'DEFAulT_AUTHENTICATION_CLASSES': [ # django默认session校验:校验规则 游客 及 登录用户 'rest_framework.authentication.SessionAuthentication','rest_framework.authentication.BasicAuthentication',],'DEFAulT_PERMISSION_CLASSES': [ # 'rest_framework.permissions.AllowAny',# 全局配置:一站式网站(所有 *** 作都需要登录后才能访问) # 'rest_framework.permissions.IsAuthenticated',}
四.失败返回的内容401 Unauthorized 未认证403 Permission DenIEd 权限被禁止 总结 以上是内存溢出为你收集整理的drf框架中认证与权限工作原理及设置全部内容,希望文章能够帮你解决drf框架中认证与权限工作原理及设置所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)