【问题标题】:How to get current user id Django如何获取当前用户 id Django
【发布时间】:2018-10-03 18:19:24
【问题描述】:

我被 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。

【问题讨论】:

    标签: django jwt


    【解决方案1】:

    您可以通过以下步骤获取令牌、用户 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'
    }
    

    【讨论】:

    • 谢谢,但我收到此错误 'username':user['username'] SyntaxError: invalid syntax ... 知道为什么吗?
    • 更新了答案。 'userid' 行后缺少逗号 (,):user['id']
    【解决方案2】:

    根据django-rest-framework-jwt docs,这个视图只返回用户名和密码(强调我的)。

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

    我不担心没有得到id,你应该可以通过用户名查询用户表。

    【讨论】:

    • 我明白了,所以我无法直接获取 id 我应该通过用户名?
    • 我不确定您的实际问题是什么?您应该能够使用用户名选择查询集
    • 我问我是否可以直接从 get_jwt_token 获取用户 ID,但显然我不能,正如你所说,我应该通过用户名来查询用户表
    • 没错,jwt中没有包含用户的id,所以你应该使用用户名来查找特定的用户
    猜你喜欢
    • 1970-01-01
    • 2013-11-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-10-05
    相关资源
    最近更新 更多