我被JWT困住了,任何人都可以告诉我如何获得用户ID以及令牌。
我的网址:
from rest_framework_jwt.views import obtain_jwt_token
from scrumboard.views import UserDetail
from scrumboard import views
urlpatterns = [
url(r'^api-token-auth/', obtain_jwt_token),
url(r'^users/$', views.UserList.as_view()),
]
views.py:
class UserList(generics.ListAPIView):
queryset = User.objects.all()
serializer_class = UserSerializer
class UserDetail(generics.RetrieveAPIView):
queryset = User.objects.all()
serializer_class = UserSerializer
serializers.py:
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ('id', 'username', 'email', 'password')
问题是,当我去api-token-auth /时,它只给我用户名和密码而不是id。
答案 0 :(得分:3)
您可以按照以下步骤获取令牌,用户ID和用户名:
在app
内,创建一个utils.py
文件(在放置serializers.py的同一级别)。
utils.py
的内容:
from .serializers import UserSerializer #you have already created UserSerializer
def jwt_response_payload_handler(token, user=None, request=None):
user = UserSerializer(user, context={'request': request}).data
return {
'token': token,
'userid': user['id'],
'username':user['username']
}
在settings.py
中,添加
JWT_AUTH = {
'JWT_RESPONSE_PAYLOAD_HANDLER':
'app_name.utils.jwt_response_payload_handler', #app_name is name of the app which contains utils.py
}
现在,当您点击api(api-token-auth /)获取令牌时,它将使用令牌,用户ID和用户名进行响应。
回复示例:
{
'token':'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJlbWFpbCI6ImdhbmVzaG5lZ2lAZ21haWwuY29tIiwiZXhwIjoxNTI0NTAyNzIzLCJ1c2VyX2lkIjoxLCJ1c2VybmFtZSI6ImdhbmVzaG5lZ2kifQ.RxnYF1gwaYywSnnWC-ngrcZaw90lpD6Rq7jcbnEoZVk',
'userid':1,
'username':'ganeshnegi'
}
答案 1 :(得分:1)
根据django-rest-framework-jwt
docs此视图仅返回用户名和密码(强调我的)。
在您的urls.py中添加[
url(r'^api-token-auth/', obtain_jwt_token)
],以便通过包含用户的用户名和密码的POST获取令牌。
我不担心没有获取ID,您应该能够通过用户名查询User表。