成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

怎么處理程序錯誤

本篇內(nèi)容主要講解“怎么處理程序錯誤”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“怎么處理程序錯誤”吧!

站在用戶的角度思考問題,與客戶深入溝通,找到鄂托克前網(wǎng)站設(shè)計與鄂托克前網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、申請域名、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋鄂托克前地區(qū)。

1

程序錯誤類型

1.1

語法錯誤

語法錯誤是因為源程序中不正確的代碼產(chǎn)生的,即在編寫程序時沒有遵守語法(或詞法)規(guī)則,書寫了錯誤的語法代碼,從而導(dǎo)致編譯器無法正確解釋源代碼而產(chǎn)生的錯誤,通常是由于錄入的錯誤引起的,它在詞法分析或語法分析時檢測出來。如“非法字符”、“括號不匹配”、“缺少;”之類的錯誤。

1.2

語義錯誤

語義錯誤是指源程序中不符合語義規(guī)則的錯誤,即一條語句試圖執(zhí)行一條不可能執(zhí)行的操作而產(chǎn)生的錯誤。語義錯誤有的在語義分析時檢測處來,有的在運行時才能檢測出來。如變量聲明錯誤、作用域錯誤、數(shù)據(jù)存儲區(qū)的溢出等錯誤。

1.3

邏輯錯誤

邏輯錯誤是指程序的運行結(jié)果和程序員的設(shè)想有出入時產(chǎn)生的錯誤。這類錯誤并不直接導(dǎo)致程序在編譯期間和運行期間出現(xiàn)錯誤,但是程序未按預(yù)期方式執(zhí)行,產(chǎn)生了不正確的運行結(jié)果,較難發(fā)現(xiàn)。這種錯誤只能通過分析結(jié)果,將結(jié)果與設(shè)計方案進行對比來發(fā)現(xiàn)。

2

HTTPException

我們用 HTTPException 模塊返回帶錯誤信息的 Response。HTTPException 是一個普通的 Python 異常,同時帶有與 API 訪問有關(guān)的附加數(shù)據(jù)。

from fastapi import FastAPI, HTTPException
app = FastAPI()
items = {"book": "Learn Python"}

@app.get("/items/{item_id}")async def read_item(item_id: str):    if item_id not in items:
       raise HTTPException(status_code=404, detail="Item not found")
   return {"item": items[item_id]}

3

添加自定義頭信息

有時候針對 HTTP 錯誤,在一些場景下,我們需要添加自定義頭信息

from fastapi import FastAPI, HTTPException
app = FastAPI()
items = {"book": "Learn Python"}

@app.get("/items-header/{item_id}")async def read_item_header(item_id: str):    if item_id not in items:        raise HTTPException(            status_code=404,            detail="Item not found",            headers={"X-Error": "error info"},
       )    return {"item": items[item_id]}

4

自定義異常處理器

在 fastapi 中借助 the same exception utilities from Starlette,我們可以添加自定義異常處理器。假設(shè)我們有個自定義異常 UnicornException,我們想在全局范圍內(nèi)處理這個異常。借助 @app.exception_handler(),就可以實現(xiàn)我們的目標(biāo)。


from fastapi import FastAPI, Requestfrom fastapi.responses import JSONResponse
class UnicornException(Exception):    def __init__(self, name: str):        self.name = name
app = FastAPI()
@app.exception_handler(UnicornException)async def unicorn_exception_handler(request: Request, exc: UnicornException):
   return JSONResponse(        status_code=418,        content={"message": f"Oops! {exc.name} did something. error"},    )
@app.get("/get_name_info/{name}")async def read_unicorn(name: str):    if name == "haishiniu":        raise UnicornException(name=name)
   return {"name": name}

5

重寫缺省異常處理器

fastapi 有一些缺省的異常處理器。當(dāng)我們拋出 HTTPException 異?;蛘弋?dāng)請求有非法數(shù)據(jù)的時候,這些處理器負(fù)責(zé)返回默認(rèn)的 JSON 結(jié)果。我們可以重寫這些異常處理器。

5.1

重寫請求校驗異常處理器

當(dāng)一個請求包含非法數(shù)據(jù)的時候,fastapi 內(nèi)部會拋出 RequestValidationError 異常,并且有默認(rèn)的異常處理器來處理。我們可以用 @app.exception_handler(RequestValidationError) 來重寫這個異常處理器。


from fastapi import FastAPI, HTTPExceptionfrom fastapi.exceptions import RequestValidationErrorfrom fastapi.responses import PlainTextResponsefrom starlette.exceptions import HTTPException as StarletteHTTPException
app = FastAPI()
@app.exception_handler(StarletteHTTPException)async def http_exception_handler(request, exc):    return PlainTextResponse(str(exc.detail), status_code=exc.status_code)

@app.exception_handler(RequestValidationError)
async def validation_exception_handler(request, exc):    return PlainTextResponse(str(exc), status_code=400)

@app.get("/items/{item_id}")async def read_item(item_id: int):    if item_id == 3:        raise HTTPException(status_code=418, detail="Nope! I don't like 3.")    return {"item_id": item_id}

5.2

重寫 HTTPException 異常處理器

同樣的方法,我們可以重寫 HTTPException 異常處理器。例如,你可能想返回純文本格式而不是 JSON 格式的錯誤信息。

from fastapi import FastAPI, HTTPExceptionfrom fastapi.exceptions import RequestValidationErrorfrom fastapi.responses import PlainTextResponsefrom starlette.exceptions import HTTPException as StarletteHTTPException
app = FastAPI()
@app.exception_handler(StarletteHTTPException)
async def http_exception_handler(request, exc):
   return PlainTextResponse(str(exc.detail), status_code=exc.status_code)
@app.exception_handler(RequestValidationError)async def validation_exception_handler(request, exc):    return PlainTextResponse(str(exc), status_code=400)

@app.get("/items/{item_id}")async def read_item(item_id: int):    if item_id == 3:
       raise HTTPException(status_code=418, detail="Nope! I don't like 3.")
   return {"item_id": item_id}

5.3

重用缺省異常處理器

我們可以導(dǎo)入并且重用缺省的異常處理器。我們從 fastapi.exception_handlers 導(dǎo)入缺省異常處理器。

from fastapi import FastAPI, HTTPExceptionfrom fastapi.exception_handlers import (    http_exception_handler,    request_validation_exception_handler,)
from fastapi.exceptions import RequestValidationErrorfrom starlette.exceptions import HTTPException as StarletteHTTPException
app = FastAPI()
@app.exception_handler(StarletteHTTPException)async def custom_http_exception_handler(request, exc):    print(f"OMG! An HTTP error!: {repr(exc)}")    return await http_exception_handler(request, exc)

@app.exception_handler(RequestValidationError)async def validation_exception_handler(request, exc):    print(f"OMG! The client sent invalid data!: {exc}")    return await request_validation_exception_handler(request, exc)


@app.get("/items/{item_id}")async def read_item(item_id: int):    if item_id == 3:        raise HTTPException(status_code=418, detail="Nope! I don't like 3.")    return {"item_id": item_id}

在示例中,我們在拋出異常之前添加了一條日志輸出。我們可以根據(jù)業(yè)務(wù)需求靈活的重用缺省異常處理器。

6

fastapi HTTPException 對比 Starlette HTTPException

fastapi 中 HTTPException 繼承自 Starlette 的 HTTPException。
唯一的區(qū)別 fastapi 中 HTTPException 允許你在 response 添加頭信息。主要在內(nèi)部用于 OAuth 2.0 以及一些安全相關(guān)的功能。
因此,通常我們在代碼中拋出 fastapi 的 HTTPException 異常。但是,當(dāng)我們注冊異常處理器的時候,我們應(yīng)該注冊為 Starlette 的 HTTPException。這樣,當(dāng) Starlette 的內(nèi)部代碼或者 Starlette 擴展插件拋出 Starlette HTTPException 時,我們的處理器才能正常捕獲和處理這個異常。如果我們要在代碼中同時使用這兩個類,為了避免命名沖突,我們可以重命名其中一個類。

到此,相信大家對“怎么處理程序錯誤”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

分享題目:怎么處理程序錯誤
路徑分享:http://jinyejixie.com/article30/pgeopo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、面包屑導(dǎo)航微信公眾號、網(wǎng)站改版企業(yè)建站、域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
威信县| 丰都县| 泗阳县| 宕昌县| 阿尔山市| 木兰县| 信丰县| 宁波市| 安新县| 长阳| 巩留县| 日照市| 公主岭市| 庆城县| 南安市| 六盘水市| 枣庄市| 云林县| 集贤县| 江孜县| 保德县| 安宁市| 格尔木市| 安溪县| 蚌埠市| 成都市| 玉林市| 丹棱县| 揭阳市| 梅州市| 汉川市| 庐江县| 宁武县| 洛南县| 南岸区| 东宁县| 石台县| 通州市| 平泉县| 砚山县| 齐齐哈尔市|