如何在Django中获取当前用户ID

3

我需要翻译的内容是:“我卡在JWT上了,有人能告诉我怎么能够通过令牌获取用户ID吗?

我的url.py文件:

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。
2个回答

3
你可以按照以下步骤获取令牌、用户ID和用户名:
在你的应用程序中,创建一个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/)获取token时,它会响应token、userid和username。
响应示例:
{
     'token':'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJlbWFpbCI6ImdhbmVzaG5lZ2lAZ21haWwuY29tIiwiZXhwIjoxNTI0NTAyNzIzLCJ1c2VyX2lkIjoxLCJ1c2VybmFtZSI6ImdhbmVzaG5lZ2kifQ.RxnYF1gwaYywSnnWC-ngrcZaw90lpD6Rq7jcbnEoZVk',
     'userid':1,
     'username':'ganeshnegi'
}

谢谢,但我遇到了这个错误 'username':user['username'] SyntaxError: invalid syntax ... 你有什么想法吗? - M1rwen
更新了答案。在“userid”行后面缺少一个逗号(,):user['id']。 - Ganesh Negi

1
根据 django-rest-framework-jwt文档 ,此视图仅返回用户名和密码(重点在于密码)。

在您的urls.py中添加 [url(r'^api-token-auth/', obtain_jwt_token)] 以通过POST获取包括用户的用户名和密码的令牌。

我不会担心无法获得id,您应该能够通过用户名查询用户表。

我明白了,所以我不能直接获取id,我应该通过用户名进行操作? - M1rwen
我不确定你的实际问题是什么?你应该能够使用用户名使你的查询集选择。 - wpercy
我问过是否可以直接从obtain_jwt_token获取用户ID,但显然我不能这样做,正如你所说,我应该通过用户名查询User表。 - M1rwen
没错,用户的id没有包含在jwt中,因此您应该使用用户名来查找特定用户。 - wpercy

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接