我正在使用 knox LoginView 来登录我的后端。这是视图的代码:
class Login(LoginView):
permission_classes = (AllowAny,)
def post(self, request, format=None):
serializer = AuthTokenSerializer(data=request.data)
serializer.is_valid(raise_exception=True)
user = serializer.validated_data['user']
login(request, user)
return super(Login, self).post(request, format=None)
当我执行我的前端(使用 Angular 开发)并尝试使用 Microsoft Edge 登录时,一切正常。我得到令牌并将其保存在本地。如果我使用 Postman 执行 POST,结果相同。但是,如果我尝试使用 Firefox 做同样的事情,我会收到 401 Unauthorized 这个 JSON:
{"detail":"Invalid token."}
如果它是 AllowAny 视图,为什么它会要求令牌?为什么它在 Edge 和 Postman 中有效,但在 Firefox 中无效?
更多数据:
这是 settings.py 中的认证类:
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'knox.auth.TokenAuthentication',
),
}
编辑:实际上,它可以使用 Firefox 开发者版。