为什么在 Django 的 AllowAny 视图中我使用 Firefox 但不使用 Edge 或 Postman 得到 401 Unauthorized ?
Why in an AllowAny view of Django I get 401 Unauthorized using Firefox but not using Edge or Postman?
我正在使用 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 中的身份验证 class:
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'knox.auth.TokenAuthentication',
),
}
编辑:实际上,它适用于 Firefox 开发者版。
我解决了清理饼干的问题。
我正在使用 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 中的身份验证 class:
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'knox.auth.TokenAuthentication',
),
}
编辑:实际上,它适用于 Firefox 开发者版。
我解决了清理饼干的问题。