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

1.当用户名和密码正确就会生成token,返回response是调用的是JWT_RESPONSE_PAYLOAD_HANDLER,如果想自定义返回体就需要重写jwt_response_payload_handler函数。
在项目目录下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', # 后面跟着你视图里定义函数
}
自定义一个视图编辑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
}]
}
现在的效果如下:
2. Django中jwt错误返回的是{"non_field_errors":["无法使用提供的认证信息登录。"]},当用户名或密码错误时,是不会去调用jwt_response_payload_handler,那么失败时调用的是什么函数了,JWT_RESPONSE_PAYLOAD_ERROR_HANDLER,但是发现这个方法并没有合到master分支,那么我们就需要手动给他合并进去。
我们打开/usr/local/lib/python3.6/site-packages/rest_framework_jwt/settings.py在IMPORT_STRINGS中添加JWT_RESPONSE_PAYLOAD_ERROR_HANDLER:
/usr/local/lib/python3.6/site-packages/rest_framework_jwt/views.py中修改:
我们在自己的视图里编写一个jwt_response_payload_error_handler函数
def jwt_response_payload_error_handler(serializer, request = None):
return {
"msg": "用户名或者密码错误",
"status": 400,
"detail": serializer.errors
}
最后我们在我们项目的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',
}
最后的样子就成为这样:
上一篇 : Laravel统一错误处理为JSON的方法介绍
下一篇 : JavaScript中EventBus实现对象之间通信
-
SEO外包最佳选择国内专业的白帽SEO机构,熟知搜索算法,各行业企业站优化策略!
SEO公司
-
可定制SEO优化套餐基于整站优化与品牌搜索展现,定制个性化营销推广方案!
SEO套餐
-
SEO入门教程多年积累SEO实战案例,从新手到专家,从入门到精通,海量的SEO学习资料!
SEO教程
-
SEO项目资源高质量SEO项目资源,稀缺性外链,优质文案代写,老域名提权,云主机相关配置折扣!
SEO资源
-
SEO快速建站快速搭建符合搜索引擎友好的企业网站,协助备案,域名选择,服务器配置等相关服务!
SEO建站
-
快速搜索引擎优化建议没有任何SEO机构,可以承诺搜索引擎排名的具体位置,如果有,那么请您多注意!专业的SEO机构,一般情况下只能确保目标关键词进入到首页或者前几页,如果您有相关问题,欢迎咨询!