django的rest_framwork

一。 rest_framwork认证:

       1. 仅使用:       

             ①.  局部认证:

               

                   解释:只需要写Authtication类,在里面写两个方法,一个认证方法,一个头方法,然后在别的类里面等于authentication_classes就行了

              ②. 全局认证:

                     1.1.先在认证文件创建一个认证类

                             

               1.2 然后在setting中指定认证的类的路径,地址用应用中写,比如我的应用是myapp,则从myapp开始

                        

            ③. 如果不让某个类视图用,则在视图类里面加上 authentication_classes = [],让这个类的这个属性为空即可

                      

       2. 源码流程:urls中匹配url   →   执行视图的类函数as_view()   →   通过as_veiw()执行dispatch()函数   →   dispatch()函数中通过initialize_request()函数对原生request进行加工   →   执行初始化函数self.initial(request, *args, **kwargs)   →   执行认证函数self.perform_authentication(request)   →   执行加工过的request对象的user函数   →   执行_authenticate()进行验证  →   验证成功后,对request对象进行赋值元组self.user, self.auth =  authenticator.authenticate(self)  

      

      3. 结论:所以使用时要给视图类的authentication_classes赋值一个认证对象,这个认证对象要返回user和auth,这样request就用user和auth的属性了

 

二。权限的使用

1. 仅使用:

      ①. 局部权限(仅作用在某个视图):

              

            详解: 编写权限类,其中一定要有方法has_permission,可以在其中判断权限,如果返回False,则不能通过,如果返回True,则通过。massage是无权限时返回的文本

       ②. 全局权限

                        

              

             详解:1.先在utils创建一个权限文件,文件中创建一个权限类SVIPPermission,然后编写权限逻辑,massage是无权限时返回的文本。

                        2. 在setting中写入红框的这段,使其成为全局权限。

      ③. 如果不让某个类视图使用权限功能,则在类添加 permission_classes = [] 即可

              

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值