Sie können rest_framework.authtoken.views.ObtainAuthToken.post
überschreiben, um das gewünschte Ergebnis zu erhalten.
myapp/views.py
from rest_framework.authtoken.views import ObtainAuthToken
from rest_framework.authtoken.models import Token
from rest_framework.response import Response
class CustomObtainAuthToken(ObtainAuthToken):
def post(self, request, *args, **kwargs):
response = super(CustomObtainAuthToken, self).post(request, *args, **kwargs)
token = Token.objects.get(key=response.data['token'])
return Response({'token': token.key, 'id': token.user_id})
myapp/urls.py
from django.conf.urls import url
from .views import CustomObtainAuthToken
urlpatterns = [
url(r'^authenticate/', CustomObtainAuthToken.as_view()),
]
Probenergebnisse
$ http :8000/authenticate/ username=someuser password=secretpassword
HTTP/1.0 200 OK
Allow: POST, OPTIONS
Content-Language: en
Content-Type: application/json
Date: Tue, 22 Mar 2017 18:30:10 GMT
Server: WSGIServer/0.2 CPython/3.5.1
Vary: Accept-Language, Cookie
X-Frame-Options: SAMEORIGIN
{
"id": 16,
"token": "82e0bc9980a6b2c9a70969b0f8dc974418dda399"
}
Die Idee, die er re ist es, die post-Methode der ObtainAuthToken-Sichtklasse zu überschreiben. Hier habe ich nur die Elternklasse aufgerufen, um das Token zu erhalten, und dann das Token nachgeschlagen, um die zugehörige Benutzer-ID zu finden.
Hoffe, dass hilft.
Ja, es hat geholfen. Genau das wollte ich erreichen. Ich hoffe, dass dies eine konsequente Lösung mit den richtigen Gewohnheiten ist. – wahtdbogh