91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django開發自定義拋出異常怎么辦

發布時間:2020-07-22 17:53:13 來源:億速云 閱讀:326 作者:小豬 欄目:開發技術

小編這次要給大家分享的是Django開發自定義拋出異常怎么辦,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

在開發過程中,針對用戶輸入的不合法信息,我們應該在后端進行數據驗證,并拋出相關的異常傳遞到前端來提示用戶。

可是如何進行自定義拋出異常信息呢?通常處理方法有三種,我將依次介紹這三種方法。

第一種方法:

這種方法最為簡單,只需要創建一個字典對象,通過render傳到前端即可。

字典對象如下:

result = {'code':'', 'message':''}
render(request, 'xxx.html', result:result)

第二種方法:

需要繼承Exception類, 代碼如下:

# 利用繼承自定義異常提示信息
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, '你的說法錯誤', '1不小于0')
except MyException as e:
  pass

第三種方法:

自定義一個繼承 object 的類

class MyTest(object):
  def __init__(self):
    # 自定義狀態碼
    self.code = 1000
    self.error = ''
    self.data = ''
 
  @property
  def dict(self):
    return self.__dict__

在你需要自定義異常的時候,創建一個對象,并制定相關信息。

# 創建實例對象
one = MyTest()
one.code = 1001
one.error = '你錯了'
one.data = '請再次檢查'
 
print(one.dict)

綜上所述是筆者常用來在后端檢驗數據并拋出相關異常信息的三種方法。

補充知識:Django rest framework 自定義異常處理

1.

在settings.py中需要添加的配置

1.install app中添加  'rest_framework',

2.在settings中的 添加這個配置

REST_FRAMEWORK = {
 'EXCEPTION_HANDLER':'common.restframework.xd_exceptions.custom_exception_handler', #這是使用自定制異常處理
}

xd_exceptions.py這里是異常處理函數

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這個key
    # response.data['message'] ='方法不對'  #增加message這個key

  return response

自定義異常類 在主動拋出異常的時候就可以拋出一個下邊類型的異常

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 # 無權限
  PARAM_ERROR = 40000 # 參數驗證錯誤
  DATA_NOT_FOUND = 40001 # 未找到數據
  DATA_NOT_VALID = 40002 # 數據錯誤
  REPEAT_POST = 40003 # 重復提交
  EEEE = 40003 # 新型錯誤

在視圖或函數中主動拋出異常,

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('用戶沒有修改權限', ErrorCode.EEEE)  #這就是拋出自定義異常, 然后自己的異常捕獲方式就能捕獲這個異常
    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)

工作流程

訪問觸發異常

自動拋出自定制異常

自定義異常捕獲函數捕獲到異常并將用戶友好的數據返回給前端

看完這篇關于Django開發自定義拋出異常怎么辦的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武山县| 和田县| 莱芜市| 荔波县| 新竹县| 托里县| 武汉市| 平顶山市| 松阳县| 九龙城区| 九寨沟县| 温州市| 吴忠市| 开封县| 二手房| 德化县| 汉阴县| 汾西县| 鹿邑县| 扶绥县| 河北省| 绥棱县| 文成县| 五河县| 法库县| 辽宁省| 甘德县| 措美县| 济宁市| 南昌市| 大宁县| 拜城县| 渝中区| 凌源市| 工布江达县| 怀集县| 晋中市| 永兴县| 高雄县| 寿宁县| 夹江县|