您的位置:首页 > 编程语言 > Go语言

自定义Django_rest_framework_jwt登陆错误返回

2019-09-05 14:10 2301 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/qq_29175605/article/details/100556939

在使用Django做前端后端项目时,登陆认证方法往往使用的是jwt_token,但是想自定义登陆成功和失败的返回体。

1.当用户名和密码正确就会生成token,返回response是调用的是
JWT_RESPONSE_PAYLOAD_HANDLER
,如果想自定义返回体就需要重写
jwt_response_payload_handler
函数。

  1. 在项目目录下settings.py中,添加
    JWT_RESPONSE_PAYLOAD_HANDLER
JWT_AUTH = {
'JWT_EXPIRATION_DELTA': datetime.timedelta(seconds=6000),
'JWT_RESPONSE_PAYLOAD_HANDLER': 'Users.views.jwt_response_payload_handler',   # 后面跟着你视图里定义函数
}
  1. 自定义一个视图编辑
    jwt_response_payload_handler
def jwt_response_payload_handler(token, user=None, request=None):
"""
设置jwt登陆返回的格式
:param token:
:param user:
:param request:
:return:
"""
return {
"msg": "success",
"status": 200,
"data": [{
# data自定义你接口想返回的信息
'token': token,
'username': user.username
}]
}
  1. 现在的效果如下:

2. Django中jwt错误返回的是
{"non_field_errors":["无法使用提供的认证信息登录。"]}
,当用户名或密码错误时,是不会去调用
jwt_response_payload_handler
,那么失败时调用的是什么函数了,
JWT_RESPONSE_PAYLOAD_ERROR_HANDLER
,但是发现这个方法并没有合到master分支,那么我们就需要手动给他合并进去。

  1. 我们打开
    /usr/local/lib/python3.6/site-packages/rest_framework_jwt/settings.py
    IMPORT_STRINGS
    中添加
    JWT_RESPONSE_PAYLOAD_ERROR_HANDLER
    :
  2. /usr/local/lib/python3.6/site-packages/rest_framework_jwt/views.py
    中修改:
  3. 我们在自己的视图里编写一个
    jwt_response_payload_error_handler
    函数
def jwt_response_payload_error_handler(serializer, request = None):
return {
"msg": "用户名或者密码错误",
"status": 400,
"detail": serializer.errors
}
  1. 最后我们在我们项目的
    settings.py
    JWT
    中添加错误返回的函数:
# jwt_token配置
JWT_AUTH = {
'JWT_EXPIRATION_DELTA': datetime.timedelta(seconds=6000),
# 登陆成功自定义 的返回结构
'JWT_RESPONSE_PAYLOAD_HANDLER': 'Users.views.jwt_response_payload_handler',
# 登陆失败时自定义的返回结构
'JWT_RESPONSE_PAYLOAD_ERROR_HANDLER': 'Users.views.jwt_response_payload_error_handler',
}
  1. 最后的样子就成为这样:
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: