自定義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’,}
最后的樣子就成為這樣:
到此這篇關于自定義Django_rest_framework_jwt登陸錯誤返回的解決的文章就介紹到這了,更多相關Django_rest_framework_jwt登陸錯誤內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章: