drf 多个认证
实现效果:除登录接口无需认证,其他接口如果从params或者头部AUTHORIZATION没有获取到token,则直接认证失败。如果去掉NoAuthentication,则支持匿名访问
认证类
from rest_framework.authentication import BaseAuthentication
from rest_framework.exceptions import AuthenticationFailed
# 参数取值认证
class ParamsAuthentication(BaseAuthentication):
def authenticate(self, request):
token = request.query_params.get('token')
if not token:
return
return 'szw', token
# header取值
class HeaderAuthentication(BaseAuthentication):
def authenticate(self, request):
token = request.META.get('HTTP_AUTHORIZATION')
if not token:
return
return 'szw', token
# 兜底认证,直接失败
class NoAuthentication(BaseAuthentication):
def authenticate(self, request):
raise AuthenticationFailed('认证失败')
settings配置
REST_FRAMEWORK = {
"UNAUTHENTICATED_USER": None,
# 认证类
"DEFAULT_AUTHENTICATION_CLASSES": ['ext.auth.ParamsAuthentication', 'ext.auth.HeaderAuthentication',
'ext.auth.NoAuthentication']
}
视图
# 无需登录
class LoginView(APIView):
# 优先读取配置项,在读取这里,后读取覆盖先读取
authentication_classes = []
def get(self, request):
print(request.user, request.auth)
return Response({'status': 'LoginView'})
# 需登录
class OrderView(APIView):
def get(self, request):
print(request.user, request.auth)
return Response({'status': 'OrderView'})
# 需登录
class UserView(APIView):
def get(self, request):
return Response({'status': 'UserView'})
本文作者:Sherwin
本文链接:https://www.cnblogs.com/sherwin1995/p/16745997.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步