Django 解決開(kāi)發(fā)自定義拋出異常的問(wèn)題
在開(kāi)發(fā)過(guò)程中,針對(duì)用戶輸入的不合法信息,我們應(yīng)該在后端進(jìn)行數(shù)據(jù)驗(yàn)證,并拋出相關(guān)的異常傳遞到前端來(lái)提示用戶。
可是如何進(jìn)行自定義拋出異常信息呢?通常處理方法有三種,我將依次介紹這三種方法。
第一種方法:
這種方法最為簡(jiǎn)單,只需要?jiǎng)?chuàng)建一個(gè)字典對(duì)象,通過(guò)render傳到前端即可。
字典對(duì)象如下:
result = {'code':'', 'message':''}
render(request, 'xxx.html', result:result)
第二種方法:
需要繼承Exception類(lèi), 代碼如下:
# 利用繼承自定義異常提示信息 class MyException(Exception): def __init__(self, code, error, data): self.code = code self.error = error self.data = data try: if not 1 < 0: raise MyException(1001, '你的說(shuō)法錯(cuò)誤', '1不小于0') except MyException as e: pass
第三種方法:
自定義一個(gè)繼承 object 的類(lèi)
class MyTest(object): def __init__(self): # 自定義狀態(tài)碼 self.code = 1000 self.error = '' self.data = '' @property def dict(self): return self.__dict__
在你需要自定義異常的時(shí)候,創(chuàng)建一個(gè)對(duì)象,并制定相關(guān)信息。
# 創(chuàng)建實(shí)例對(duì)象 one = MyTest() one.code = 1001 one.error = '你錯(cuò)了' one.data = '請(qǐng)?jiān)俅螜z查' print(one.dict)
綜上所述是筆者常用來(lái)在后端檢驗(yàn)數(shù)據(jù)并拋出相關(guān)異常信息的三種方法。
補(bǔ)充知識(shí):Django rest framework 自定義異常處理
1.
在settings.py中需要添加的配置
1.install app中添加 'rest_framework',
2.在settings中的 添加這個(gè)配置
REST_FRAMEWORK = {
'EXCEPTION_HANDLER':'common.restframework.xd_exceptions.custom_exception_handler', #這是使用自定制異常處理
}
xd_exceptions.py這里是異常處理函數(shù)
from rest_framework.views import exception_handler def custom_exception_handler(exc, context): # Call REST framework's default exception handler first, # to get the standard error response. response = exception_handler(exc, context) # Now add the HTTP status code to the response. if response is not None: response.data['status_code'] = response.status_code print(response.data) # response.data['message'] =response.data['detail'] #增加message這個(gè)key # response.data['message'] ='方法不對(duì)' #增加message這個(gè)key return response
自定義異常類(lèi) 在主動(dòng)拋出異常的時(shí)候就可以拋出一個(gè)下邊類(lèi)型的異常
my_errors.py
from rest_framework import status from rest_framework.exceptions import APIException from common.tools import xd_status # class ParseError(APIException): # status_code = xd_status.HTTP_400_BAD_REQUEST # default_detail = '這是.default_detail========' # default_code = 'parse_error' # class XdError(APIException): pass class ParamError(XdError): status_code = 400 class Unauthorized(XdError): status_code = 401 class PermissionDenied(XdError): status_code = 403 class ObjectNotFound(XdError): status_code = 404 class ServerError(XdError): status_code = 500 class ErrorCode: UNAUTHORIZED = 10000 # 未登錄 PERMISSION_DENIED = 10001 # 無(wú)權(quán)限 PARAM_ERROR = 40000 # 參數(shù)驗(yàn)證錯(cuò)誤 DATA_NOT_FOUND = 40001 # 未找到數(shù)據(jù) DATA_NOT_VALID = 40002 # 數(shù)據(jù)錯(cuò)誤 REPEAT_POST = 40003 # 重復(fù)提交 EEEE = 40003 # 新型錯(cuò)誤
在視圖或函數(shù)中主動(dòng)拋出異常,
class SupserUserDetailView(APIView): # authentication_classes = [] permission_classes = [SupserPermisson,] def put(self,request,pk): if not request.user.is_superuser: if request.user.id != pk: raise ParamError('用戶沒(méi)有修改權(quán)限', ErrorCode.EEEE) #這就是拋出自定義異常, 然后自己的異常捕獲方式就能捕獲這個(gè)異常 user = User.objects.filter(id=pk) if not user: raise ParamError('被修改的用戶不存在', ErrorCode.EEEE) data = handel_c_user(request.data) user_obj = Creat_newuser_serializers(data=data, instance=user.first()) if user_obj.is_valid(): user_obj.save() res={'status':"修改成功"} return JsonResponse(data=res, code=200, desc="success", status=status.HTTP_200_OK) res = {'status':user_obj.errors} return JsonResponse(data=res,code=200,desc="success",status=status.HTTP_200_OK)
工作流程
訪問(wèn)觸發(fā)異常
自動(dòng)拋出自定制異常
自定義異常捕獲函數(shù)捕獲到異常并將用戶友好的數(shù)據(jù)返回給前端
以上這篇Django 解決開(kāi)發(fā)自定義拋出異常的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu)示例代碼
在Python中,分支結(jié)構(gòu)通過(guò)if、elif和else關(guān)鍵字來(lái)實(shí)現(xiàn)條件判斷,在使用if語(yǔ)句時(shí),程序會(huì)根據(jù)條件表達(dá)式的真假執(zhí)行相應(yīng)的代碼塊,這篇文章主要介紹了Python分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu),需要的朋友可以參考下2024-03-03Python中Numpy包的安裝與使用方法簡(jiǎn)明教程
這篇文章主要介紹了Python中Numpy包的安裝與使用方法,結(jié)合簡(jiǎn)單實(shí)例形式分析了Python使用pip命令在線與離線whl包安裝,以及使用numpy打印隨機(jī)數(shù)矩陣的操作技巧,需要的朋友可以參考下2018-07-07Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn)
本文主要介紹了Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02Pytorch實(shí)現(xiàn)常用乘法算子TensorRT的示例代碼
pytorch 用于訓(xùn)練,TensorRT用于推理是很多AI應(yīng)用開(kāi)發(fā)的標(biāo)配。大家往往更加熟悉 pytorch 的算子,而不太熟悉TensorRT的算子。本文介紹了Pytorch中常用乘法的TensorRT實(shí)現(xiàn),感興趣的可以了解一下2022-06-06python第三方庫(kù)subprocess執(zhí)行cmd同時(shí)輸入密碼獲取參數(shù)
本文給大家介紹python subprocess執(zhí)行cmd同時(shí)輸入密碼獲取參數(shù),手動(dòng)輸入cmd命令,本文給大家逐一介紹這個(gè)命令的使用方法,感興趣的朋友跟隨小編一起看看吧2024-01-01Python框架Flask的基本數(shù)據(jù)庫(kù)操作方法分析
這篇文章主要介紹了Python框架Flask的基本數(shù)據(jù)庫(kù)操作方法,結(jié)合實(shí)例形式分析了Flask框架數(shù)據(jù)庫(kù)操作常用函數(shù)功能、用法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2018-07-07Python基于twisted實(shí)現(xiàn)簡(jiǎn)單的web服務(wù)器
這篇文章主要介紹了Python基于twisted實(shí)現(xiàn)簡(jiǎn)單的web服務(wù)器,可模擬出簡(jiǎn)單的web服務(wù)器功能,是很實(shí)用的技巧,需要的朋友可以參考下2014-09-09Jupyter安裝鏈接aconda實(shí)現(xiàn)過(guò)程圖解
這篇文章主要介紹了Jupyter安裝鏈接aconda實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11