Аутентификация токена не работает на Django Rest Framework - PullRequest
0 голосов
/ 17 сентября 2018

У меня есть приложение Django, в котором я использую DRF для своего API с сеансом и аутентификацию токена. У меня есть rest_framework и rest_framework.authtoken в моих установленных приложениях. Я перенес свою базу данных и могу создавать токены для пользователей в Django Admin. Я знаю, что все это работает, потому что я получаю доступ к представлению rest_framework.auth_token receive_auth_token для возврата токена, когда пользовательские данные отправляются в запросе POST, и получаю его обратно. Когда я пытаюсь выполнить GET-запрос к функции просмотра в моем приложении, для которого в наборе параметров отображается TokenAuthentication, он продолжает возвращаться.

{"detail":"Authentication credentials were not provided."}

Файл настроек

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    # My Apps
    'rest_framework',
    'rest_auth',
    'rest_framework.authtoken',
]

REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': [
        'rest_framework.authentication.SessionAuthentication',
        'rest_framework.authentication.TokenAuthentication',
    ],
}

URLS

from django.urls import path, include
from rest_framework.routers import DefaultRouter
from rest_framework.authtoken import views

from api.views.some_model import MyViewSet

urlpatterns = [
    path('', include(router.urls)),
    path('rest-auth/', include('rest_auth.urls')),
    path('api-token-auth/', views.obtain_auth_token)
]

Viewset

from rest_framework.viewsets import ModelViewSet
from rest_framework.authentication import SessionAuthentication, TokenAuthentication
from rest_framework.permissions import IsAuthenticated

from some_app.models import SomeModel
from api.serializers.exams import SomeModelSerializer


class ExamViewSet(ModelViewSet):
    permission_classes = (IsAuthenticated,)
    authentication_classes = (TokenAuthentication, SessionAuthentication)

    queryset = SomeModel.objects.all()
    serializer_class = SomeModelSerializer

Скрипт Python для получения ответа

import requests
import json

data = {
    "username": "myemail@gmail.com",
    "password": "password124"
}
url = "http://localhost:8002/api/v1/api-token-auth/"
response = requests.post(url, data=data)
token = json.loads(response.text).get('token')

if token:
    token = f"Token {token}"
    headers = {"Authentication": token}
    response = requests.get("http://localhost:8002/api/v1/model/", headers=headers)
    print(response.text)
else:
    print('No Key')

1 Ответ

0 голосов
/ 17 сентября 2018

Имя заголовка должно быть Authorization, а не Authentication:

headers = {"Authorization": token}
response = requests.get("http://localhost:8002/api/v1/model/", headers=headers)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...