早上好,
我正在编写我的第一个DRF,并使用django-rest-framework-jwt (https://getblimp.github.io/django-rest-framework-jwt/)来处理JWT身份验证。
我目前使用的是内置视图:
from rest_framework_jwt.views import obtain_jwt_token
from rest_framework_jwt.views import refresh_jwt_token
urlpatterns = [
path('auth/obtain_token/', obtain_jwt_token),
path('auth/refresh_token/', refresh_jwt_token),但是需要将一些用户信息返回给UI (VueJS)。我想将用户ID和姓名信息存储到Vuex存储中,以便传递给后续的API调用并呈现给用户("Hello Jim!")。
我在讨论为jwt有效负载响应添加自定义函数时发现了以下内容:jwt rest framework returning user id with token
我不知道在哪里做这件事...
感谢你的帮助,澄清。
BCBB
发布于 2019-02-07 22:47:12
有几个解决方案
1)首先,用户id被编码到JWT中,你可以自己在js中解码。
2)您可以覆盖从django-rest-framework-jwt返回的有效负载,如下所示:例如,将以下代码放入accounts应用程序的一个名为utils.py的文件中
def jwt_response_payload_handler(token, user=None, request=None):
return {
'token': token,
'username': user.username,
'user_id' : user.id,
'email' : user.email
}并在rest-framework-jwt设置中替换
'JWT_RESPONSE_PAYLOAD_HANDLER':
'rest_framework_jwt.utils.jwt_response_payload_handler',有了这个
'JWT_RESPONSE_PAYLOAD_HANDLER':
'accounts.utils.jwt_response_payload_handler',https://stackoverflow.com/questions/54575716
复制相似问题