成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Django REST framework 異常處理

瀏覽:5日期:2024-09-03 16:58:22
目錄寫在前面DRF異常處理1. DRF 常見的異常2. 自定義異常3. 使用自定義異常4. 驗證結果異常處理進階1. 修改自定義異常2. 自定義更多異常3. 新增測試接口4. 驗證結果總結參考資料寫在前面

這兩天一直在思索關于 DRF 還有哪些是項目必備的而且還沒有說到的基礎性的知識。這不昨天寫到日志相關的功能就直接想到還有異常處理相關的功能,其實在之前項目中初期是沒有統一的異常捕獲手段。可能是 DRF 自帶的異常 能滿足大多數功能,也可能是比較懶,就使用比較粗暴的方式,以狀態碼 500 的方式去拋出異常,然后在日志中可以看到所有的異常信息。這么做呢,代碼其實是不夠健壯的,前端在調用的時候莫名的 500 也是不夠友好的,所以今天就補充一下異常相關的知識。

DRF異常處理1. DRF 常見的異常 AuthenticationFailed/ NotAuthenticated 一般該異常狀態碼為'401 Unauthenticated',主要是沒有登錄鑒權的時候會返回,可以用在自定義登錄的時候。 PermissionDenied 一般用在鑒權時候使用,一般狀態碼為'403 Forbidden'。 ValidationError 一般狀態碼為'400 Bad Request',主要是 serializers 中對字段的校驗,比如對字段類型的校驗、字段長度的校驗以及自定義字段格式的校驗。2. 自定義異常

這里對異常的定義主要的想法來自 ValidationError,統一異常返回的格式,方便前端統一處理類似異常。

自定義異常

# 新建 utils/custom_exception.pyclass CustomException(Exception): _default_code = 400 def __init__(self,message: str = '',status_code=status.HTTP_400_BAD_REQUEST,data=None,code: int = _default_code, ):self.code = codeself.status = status_codeself.message = messageif data is None: self.data = {'detail': message}else: self.data = data def __str__(self):return self.message

自定義異常處理

# utils/custom_exception.pyfrom rest_framework.views import exception_handlerdef custom_exception_handler(exc, context): # Call REST framework’s default exception handler first, # to get the standard error response.# 這里對自定義的 CustomException 直接返回,保證系統其他異常不受影響 if isinstance(exc, CustomException):return Response(data=exc.data, status=exc.status) response = exception_handler(exc, context) return response

配置自定義異常處理類

REST_FRAMEWORK = { # ... 'EXCEPTION_HANDLER': 'utils.custom_exception.custom_exception_handler',}3. 使用自定義異常

使用之前文章的接口用來測試自定義異常的處理

class ArticleViewSet(viewsets.ModelViewSet): ''' 允許用戶查看或編輯的API路徑。 ''' queryset = Article.objects.all() serializer_class = ArticleSerializer @action(detail=False, methods=['get'], url_name='exception', url_path='exception') def exception(self, request, *args, **kwargs):# 日志使用 demologger.error('自定義異常')raise CustomException(data={'detail': '自定義異常'})4. 驗證結果

$ curl -H ’Accept: application/json; indent=4’ -u admin:admin http://127.0.0.1:8000/api/article/exception/{ 'detail': '自定義異常'}異常處理進階

上面的代碼雖說是可以滿足90%的需求,但是錯誤的定義太泛泛。難以集中定義管理錯誤,與常見項目中自定義的異常比較優點就是靈活,但是隨著代碼中拋出的異常越來越多加之散落在各個角落,不利于更新維護。所以下面對修改一下代碼,對異常有統一的定義,同時也支持自定義返回HTTP狀態碼。

1. 修改自定義異常

# utils/custom_exception.pyclass CustomException(Exception): # 自定義code default_code = 400 # 自定義 message default_message = None def __init__( self, status_code=status.HTTP_400_BAD_REQUEST, code: int = None, message: str = None, data=None, ):self.status = status_codeself.code = self.default_code if code is None else codeself.message = self.default_message if message is None else messageif data is None: self.data = {'detail': self.message, 'code': self.code}else: self.data = data def __str__(self):return str(self.code) + self.message2. 自定義更多異常

class ExecuteError(CustomException): '''執行出錯''' default_code = 500 default_message = '執行出錯'class UnKnowError(CustomException): '''執行出錯''' default_code = 500 default_message = '未知出錯'3. 新增測試接口

class ArticleViewSet(viewsets.ModelViewSet): ''' 允許用戶查看或編輯的API路徑。 ''' queryset = Article.objects.all() serializer_class = ArticleSerializer @action(detail=False, methods=['get'], url_name='exception', url_path='exception') def exception(self, request, *args, **kwargs):# 日志使用 demologger.error('自定義異常')raise CustomException(data={'detail': '自定義異常'}) @action(detail=False, methods=['get'], url_name='unknown', url_path='unknown') def unknown(self, request, *args, **kwargs):# 日志使用 demologger.error('未知錯誤')raise UnknownError() @action(detail=False, methods=['get'], url_name='execute', url_path='execute') def execute(self, request, *args, **kwargs):# 日志使用 demologger.error('執行錯誤')raise ExecuteError()4. 驗證結果

curl -H ’Accept: application/json; indent=4’ -u admin:admin http://127.0.0.1:8000/api/article/unknown/{ 'detail': '未知出錯', 'code': 500}$ curl -H ’Accept: application/json; indent=4’ -u admin:admin http://127.0.0.1:8000/api/article/execute/{ 'detail': '執行出錯', 'code': 500}總結

需要注意自定義的異常處理函數需要在處理完成自定義異常后繼續執行 rest_framework.views.exception_handler,因為這里的執行仍然需要兼容已有的異常處理;下面貼一下 DRF 有關的異常處理邏輯。

該處理函數默認處理 APIException以及 Django 內部的 Http404 PermissionDenied,其他的異常會返回 None ,會觸發 DRF 500 的錯誤。

def exception_handler(exc, context): ''' Returns the response that should be used for any given exception. By default we handle the REST framework `APIException`, and also Django’s built-in `Http404` and `PermissionDenied` exceptions. Any unhandled exceptions may return `None`, which will cause a 500 error to be raised. ''' if isinstance(exc, Http404):exc = exceptions.NotFound() elif isinstance(exc, PermissionDenied):exc = exceptions.PermissionDenied() if isinstance(exc, exceptions.APIException):headers = {}if getattr(exc, ’auth_header’, None): headers[’WWW-Authenticate’] = exc.auth_headerif getattr(exc, ’wait’, None): headers[’Retry-After’] = ’%d’ % exc.waitif isinstance(exc.detail, (list, dict)): data = exc.detailelse: data = {’detail’: exc.detail}set_rollback()return Response(data, status=exc.status_code, headers=headers) return None參考資料

Django REST framework 異常文檔Django 異常文檔

到此這篇關于Django REST framework 異常處理的文章就介紹到這了,更多相關Django REST framework 異常內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Django
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品区一区| 婷婷成人激情在线网| 国产精品少妇自拍| 精品一区二区三区日韩| 国产伦精品一区二区三| 亚洲天天做日日做天天谢日日欢| 成人免费精品视频| 欧美绝品在线观看成人午夜影视| 日韩av成人高清| 国产精品毛片va一区二区三区| 国产欧美精品一区二区色综合| 国产一区二区三区高清播放| 欧美影院精品一区| 亚洲乱码国产乱码精品精小说| 欧美日韩国产一区精品一区| 久久精品欧美一区二区三区不卡| 粉嫩av一区二区三区在线播放| 欧美性大战xxxxx久久久| 亚洲一区二区三区中文字幕| 国产精品v欧美精品v日韩| 日韩视频一区二区三区在线播放| 午夜欧美在线一二页| 成人黄色小视频在线观看| 欧美专区亚洲专区| 日韩精品专区在线影院重磅| 午夜电影一区二区| 在线免费观看欧美| 老司机精品视频网站| 国产精品久久久久国产精品日日| 成人一二三区视频| 懂色av一区二区三区免费看| 在线视频观看一区| 有坂深雪av一区二区精品| 国产精品hd| 久久久久国产一区二区三区四区| 国产成人自拍在线| 欧美日本乱大交xxxxx| 亚洲国产一区二区三区a毛片| 精品国产一区二区三区不卡| 日本午夜精品视频在线观看| 在线一区免费观看| 国产精品另类一区| av电影在线观看完整版一区二区| 一本色道久久综合亚洲aⅴ蜜桃| 亚洲人一二三区| 欧美激情第10页| 欧美一区二区三区在线观看| 免费av成人在线| 99在线|亚洲一区二区| 国产精品免费视频观看| 91在线观看成人| 精品裸体舞一区二区三区| 日韩av在线发布| 欧美一级专区| 一区二区三区不卡在线观看| 99精品热6080yy久久| 亚洲人成人一区二区在线观看 | 91精选在线观看| 久久精品99久久久| 久久亚洲影院| 亚洲女女做受ⅹxx高潮| 欧美区日韩区| 欧美人与z0zoxxxx视频| 久久精品99国产精品| 色欧美日韩亚洲| 视频一区二区国产| 欧美三级视频| 国产精品麻豆视频| 欧美日韩1080p| 国产精品久久久久影院| 韩日成人在线| 最近日韩中文字幕| 亚洲国产黄色| 亚洲蜜臀av乱码久久精品蜜桃| 在线观看成人一级片| 自拍偷在线精品自拍偷无码专区 | 激情综合色综合久久综合| 欧美三级蜜桃2在线观看| 青青草国产精品97视觉盛宴| 欧美综合欧美视频| 国内成人自拍视频| 日韩一级在线观看| 大胆欧美人体老妇| 精品三级av在线| 欧美一区91| 亚洲精品网站在线观看| 国产欧美大片| 青青草国产成人av片免费| 欧美日韩一卡二卡| 高清不卡在线观看av| 久久久久久久综合日本| 亚洲天堂偷拍| 亚洲午夜久久久久中文字幕久| 色综合久久久久综合体| 久久99精品网久久| 日韩视频中午一区| 国产精品动漫网站| 99精品视频免费观看| 日韩在线播放一区二区| 欧美日韩久久一区二区| 国产老女人精品毛片久久| 欧美一区二区三区在线观看视频| 久久精品国产一区二区三| 欧美日韩久久久| aaa亚洲精品一二三区| 国产精品理伦片| 性一交一乱一区二区洋洋av| 奇米777欧美一区二区| 日韩西西人体444www| 欧美日韩亚洲国产精品| 香蕉久久夜色精品国产使用方法 | 欧美国产精品久久| 99国产精品自拍| 日本不卡视频在线观看| 欧美一级免费大片| 国产精品vip| 男人的天堂亚洲一区| 精品免费国产二区三区 | 日本一区二区三区四区在线视频| 在线视频欧美一区| 日韩av一二三| 欧美一区二区三区色| 91免费国产在线| 伊人一区二区三区| 9191成人精品久久| 欧美午夜在线| 日本午夜精品视频在线观看| 亚洲精品一线二线三线| 夜夜嗨网站十八久久| 精品亚洲成a人| 日本一二三四高清不卡| 久久久综合网| 成人app软件下载大全免费| 一区二区三区久久久| 制服丝袜av成人在线看| 好吊一区二区三区| 日韩av电影天堂| 亚洲精品在线免费观看视频| 国产精品久久久免费| 国产精品91xxx| 亚洲蜜臀av乱码久久精品蜜桃| 538prom精品视频线放| 亚洲精品一级| 久久99精品一区二区三区| 久久久影院官网| 香蕉成人久久| 成人动漫一区二区| 亚洲一级二级三级在线免费观看| 精品日韩一区二区三区 | 波多野结衣亚洲| 亚洲六月丁香色婷婷综合久久| 欧美日本精品一区二区三区| 伊人久久大香线蕉av超碰演员| 一区二区在线观看不卡| 欧美一区二区三区男人的天堂| 午夜国产精品视频| 九九九精品视频| 亚洲欧美日韩在线播放| 91精品在线观看入口| 在线视频一区观看| a亚洲天堂av| 欧美a级理论片| 中文字幕在线不卡| 日韩一级高清毛片| 久久精品伊人| 99视频超级精品| 爽爽淫人综合网网站| 国产视频一区二区在线观看| 亚洲自拍欧美精品| 国产无一区二区| 欧美美女bb生活片| 夜夜精品视频| 91丝袜美腿高跟国产极品老师| 日本一区二区三区久久久久久久久不| 色哦色哦哦色天天综合| 97久久超碰精品国产| 精品一区二区在线看| 亚洲色图在线看| 欧美一区二区三区在线| 亚洲综合精品| 国内视频一区| 国产91精品露脸国语对白| 丝袜诱惑亚洲看片| 亚洲免费在线观看视频| 精品理论电影在线观看 | 在线视频国内自拍亚洲视频| 亚洲国产精品视频一区| 顶级嫩模精品视频在线看| 亚洲高清免费一级二级三级| 国产日韩亚洲欧美综合| 欧美一区二区三区免费观看视频| 免费亚洲婷婷| 亚洲欧洲一级| 97久久超碰精品国产| 久草在线在线精品观看| 日韩一级片网址| 欧美日韩一区二区三区不卡| 久久亚洲国产精品日日av夜夜| 尹人成人综合网| 你懂的一区二区|