rest_framwork

一。 rest_framwork认证:

       1. 仅使用:       

             ①.  局部认证:

               rest_framwork

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

              ②. 全局认证:

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

                         rest_framwork    rest_framwork

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

                        rest_framwork

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

                      rest_framwork

       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)  

      rest_framwork

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

 

二。权限的使用

1. 仅使用:

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

              rest_framwork

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

       ②. 全局权限

               rest_framwork         rest_framwork

             rest_framwork 

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

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

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

              rest_framwork