亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Django 解決開(kāi)發(fā)自定義拋出異常的問(wèn)題

 更新時(shí)間:2020年05月21日 10:55:00   作者:Amberdreams  
這篇文章主要介紹了Django 解決開(kāi)發(fā)自定義拋出異常的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

在開(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)和循環(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-03
  • Python中Numpy包的安裝與使用方法簡(jiǎn)明教程

    Python中Numpy包的安裝與使用方法簡(jiǎn)明教程

    這篇文章主要介紹了Python中Numpy包的安裝與使用方法,結(jié)合簡(jiǎn)單實(shí)例形式分析了Python使用pip命令在線與離線whl包安裝,以及使用numpy打印隨機(jī)數(shù)矩陣的操作技巧,需要的朋友可以參考下
    2018-07-07
  • 基于python 處理中文路徑的終極解決方法

    基于python 處理中文路徑的終極解決方法

    下面小編就為大家分享一篇基于python 處理中文路徑的終極解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • python實(shí)現(xiàn)的文件夾清理程序分享

    python實(shí)現(xiàn)的文件夾清理程序分享

    這篇文章主要介紹了python實(shí)現(xiàn)的文件夾清理程序分享,可以按時(shí)間清理和指定配置文件清理,需要的朋友可以參考下
    2014-11-11
  • Python multiprocessing 進(jìn)程間通信方式實(shí)現(xiàn)

    Python 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-02
  • Pytorch實(shí)現(xiàn)常用乘法算子TensorRT的示例代碼

    Pytorch實(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-06
  • python第三方庫(kù)subprocess執(zhí)行cmd同時(shí)輸入密碼獲取參數(shù)

    python第三方庫(kù)subprocess執(zhí)行cmd同時(shí)輸入密碼獲取參數(shù)

    本文給大家介紹python subprocess執(zhí)行cmd同時(shí)輸入密碼獲取參數(shù),手動(dòng)輸入cmd命令,本文給大家逐一介紹這個(gè)命令的使用方法,感興趣的朋友跟隨小編一起看看吧
    2024-01-01
  • Python框架Flask的基本數(shù)據(jù)庫(kù)操作方法分析

    Python框架Flask的基本數(shù)據(jù)庫(kù)操作方法分析

    這篇文章主要介紹了Python框架Flask的基本數(shù)據(jù)庫(kù)操作方法,結(jié)合實(shí)例形式分析了Flask框架數(shù)據(jù)庫(kù)操作常用函數(shù)功能、用法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2018-07-07
  • Python基于twisted實(shí)現(xiàn)簡(jiǎn)單的web服務(wù)器

    Python基于twisted實(shí)現(xiàn)簡(jiǎn)單的web服務(wù)器

    這篇文章主要介紹了Python基于twisted實(shí)現(xiàn)簡(jiǎn)單的web服務(wù)器,可模擬出簡(jiǎn)單的web服務(wù)器功能,是很實(shí)用的技巧,需要的朋友可以參考下
    2014-09-09
  • Jupyter安裝鏈接aconda實(shí)現(xiàn)過(guò)程圖解

    Jupyter安裝鏈接aconda實(shí)現(xiàn)過(guò)程圖解

    這篇文章主要介紹了Jupyter安裝鏈接aconda實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11

最新評(píng)論