认证
认证,在执行视图之前执行了三大认证
认证的使用方法
'''
1 写一个类,继承BaseAuthentication
2 在类中写authenticate方法
3 在方法中,完成登录认证,如果不是登录,抛异常
token = request.GET.get("token") user_taken = UserTaken.objects.filter(token=token).first() if not user_taken: raise AuthenticationFailed("你暂时没有登录")
4 如果登录成功,返回登录用户和token
`return user_taken.user, token`
5 在视图类中使用,(局部使用)
authentication_classes = [UserAuthentication] # 局部
6 全局使用
`REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': [
'应用名.模块名.类名', # 认证
],
}`
7 全局使用后,局部禁用
`REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': [
'应用名.模块名.类名', # 认证
],
}`
局部禁用
authentication_classes = []
8 认证类的使用顺序
-先使用局部
-在使用项目配置文件
-使用drf默认配置
重点,一旦通过了认证,在request中就有当前登录用户