」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何在沒有 Swagger UI 的情況下將 JSON 資料發佈到 FastAPI 後端?

如何在沒有 Swagger UI 的情況下將 JSON 資料發佈到 FastAPI 後端?

發佈於2024-11-10
瀏覽:967

How to Post JSON Data to a FastAPI Backend Without Swagger UI?

在沒有Swagger UI 的情況下將JSON 資料直接發佈到FastAPI 後端

FastAPI 允許使用者輕鬆地將JSON 資料發佈到其後端,即使不使用Swagger UI 提供的自動化文件。本文深入探討了將資料直接發佈到後端 URL 並在瀏覽器中顯示結果的簡單過程。

創建FastAPI 應用程式

首先建立一個基本的應用程式具有POST 操作和用於反序列化JSON 有效負載的模型類別的FastAPI 應用程式:

from fastapi import FastAPI
from pydantic import BaseModel

class Item(BaseModel):
    name: str
    roll: int

app = FastAPI()

@app.post("/")
async def create_item(item: Item):
    return item

使用 JavaScript 實作前端

對於前端,我們將利用 Fetch API,它使我們能夠將 JSON 資料直接傳送到後端 URL。

fetch('/', {
    method: 'POST',
    headers: {
        'Accept': 'application/json',
        'Content-Type': 'application/json'
    },
    body: JSON.stringify({name: "XYZ", roll: 51})
})
.then(resp => resp.text())
.then(data => {
    console.log(data);  // Display the result in the browser
})
.catch(error => {
    console.error(error);
});

在此腳本中,我們建立一個 POST 請求,指定正確的標頭並將資料轉換為 JSON 字串。然後,伺服器回應將顯示在瀏覽器中。

替代方法

將資料發佈至FastAPI 後端的其他方法包括:

  • 表單資料:使用基於表單的方法使用FormData 類別提交資料。
  • 文件和表單/JSON 資料:利用文件和表單的組合/用於更複雜場景的 JSON 資料。

結論

在沒有Swagger UI 的情況下將JSON 資料發佈到FastAPI 後端是一個簡單的過程,需要使用JavaScript 發送資料直接發送到後端URL。您可以選擇最適合您需求的各種方法,無論是基於表單的資料提交還是文件和表單/JSON 資料的組合。

版本聲明 本文轉載於:1729686577如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 如何從 PHP 字串中的字元中刪除重音符號而不遇到意外的替換?
    如何從 PHP 字串中的字元中刪除重音符號而不遇到意外的替換?
    如何從 PHP 字串中的字元中刪除重音符號? 在 glibc 實作中使用 iconv 可能會導致意外的字元替換,例如問號當嘗試從 PHP 字串中的字元中刪除重音符號時。 問題源自於 iconv 和 glibc 實作之間的不相容,這不如首選的 libiconv 實作那麼可靠。若要解決此問題,請確保 P...
    程式設計 發佈於2024-11-18
  • 如何在沒有外部依賴的情況下使用Python在Linux中擷取螢幕截圖?
    如何在沒有外部依賴的情況下使用Python在Linux中擷取螢幕截圖?
    使用 Python 在 Linux 中捕獲螢幕截圖在各種 Linux 環境中,需要以不顯眼的方式捕獲螢幕截圖以用於文件或分析目的。利用 Python 強大的腳本功能,我們探索了一種在不透露任何可見幹擾的情況下截取螢幕截圖的腳本方法。 下面的 Python 腳本利用 GTK 綁定來檢索螢幕解析度和像素...
    程式設計 發佈於2024-11-18
  • 如何從不同子網域上的 iFrame 取得父頁面的 URL?
    如何從不同子網域上的 iFrame 取得父頁面的 URL?
    從iFrame 訪問父級URL:限制和解決方法從iFrame 訪問父級框架的URL 可能是一項挑戰,特別是當iFrame 位於不同的子域上。這是由於跨站點腳本 (XSS) 預防措施所施加的安全限制。 從與父框架相同的域和子域存取 iFrame 時,應使用諸如 Parent 之類的表達式直接存取父級的...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-18
  • 如何與非技術人員進行技術對話?
    如何與非技術人員進行技術對話?
    我的葡萄牙老師總是在解釋結束時說:我了解自己了嗎? 因為如果不理解,所有的解釋都毫無價值! 您是否曾嘗試向其他領域的人解釋技術主題卻無法被理解? 這對任何部門來說都是一個挑戰,如果從一開始就做什麼達成協議,缺乏溝通會阻礙交付時間,甚至導致採取完全相反的路徑。 我經歷了好幾次這樣的事情,因為我...
    程式設計 發佈於2024-11-18
  • 將布林值轉換為整數總是得到 0 或 1 嗎?
    將布林值轉換為整數總是得到 0 或 1 嗎?
    布林值轉換為整數時是否總是為零或一? 當布林值轉換為整數時,許多編譯器似乎只保留 0 或 1,這引發了有關此行為可靠性的問題。讓我們來看一個例子:int a = 2; bool b = a; int c = 3 b; // What is the result? 4 or 5?答案: 是的,bo...
    程式設計 發佈於2024-11-18
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST數組:表單提交後使用var_dump檢查$_POST 陣列的內容。...
    程式設計 發佈於2024-11-18
  • 為什麼從 std::string 函數傳回 C 字串文字有時似乎有效,但仍然是未定義的行為?
    為什麼從 std::string 函數傳回 C 字串文字有時似乎有效,但仍然是未定義的行為?
    從std::string 函數回傳C 字串文字並呼叫c_str()在C 中,從std::string 函數傳回C 字串文字是不明智的做法可能會導致不確定的行為。然而,一個常見的誤解是這段程式碼應該會失敗,儘管它在某些情況下似乎可以運作。 當「是我!!」傳遞給 myFunction() 時,C 字串文...
    程式設計 發佈於2024-11-18
  • 如何使用 array_diff 來決定一個陣列是否包含另一個陣列中的所有值?
    如何使用 array_diff 來決定一個陣列是否包含另一個陣列中的所有值?
    使用 array_diff 檢查陣列值包含使用 array_diff 檢查陣列值包含$all = array ( 0 =&gt; 307, 1 =&gt; 157, 2 =&gt; 234, 3 =&gt; 200, 4 =&a...
    程式設計 發佈於2024-11-18
  • 如何在 Go 中正確實作自訂類型的 Valuer 和 Scanner?
    如何在 Go 中正確實作自訂類型的 Valuer 和 Scanner?
    Golang 類型斷言:為自訂型別實作Valuer 和Scanner在Go 中使用自訂型別(例如基於字串的型別)時,可能需要實作Valuer 和Scanner 介面來與資料庫驅動程式互動。這使得自訂類型能夠與資料庫值進行序列化和反序列化。 在提供的程式碼中,嘗試實作 Role 型別及其關聯的 Val...
    程式設計 發佈於2024-11-18
  • 如何讓 MySQL 截斷資料而不是在插入時引發錯誤?
    如何讓 MySQL 截斷資料而不是在插入時引發錯誤?
    MySQL 插入行為:截斷與錯誤MySQL 插入行為:截斷與錯誤MySQL 在嘗試插入超出列長度限制的資料時表現出不同的行為:截斷或錯誤。在這種情況下,我們的目標是修改 MySQL 實例以截斷資料而不是引發錯誤。 解決方案:停用 STRICT_TRANS_TABLES 和 STRICT_ALL_TA...
    程式設計 發佈於2024-11-18
  • 如何阻止 Flexbox 中的 Flex 項目伸展?
    如何阻止 Flexbox 中的 Flex 項目伸展?
    防止 Flex 項目拉伸使用 Flexbox 佈局時,Flex 項目可以拉伸並填充其容器中的可用空間。但是,在某些情況下,您可能希望防止這種情況發生。 為什麼 Flex 專案可以伸展? 預設情況下,Flex 專案將沿主軸拉伸容器的形狀,通常是水平(行)或垂直(列)。這是因為 flex 屬性預設為 1...
    程式設計 發佈於2024-11-18
  • 如何在 Visual Studio 2012 中連接 MySQL 資料庫?
    如何在 Visual Studio 2012 中連接 MySQL 資料庫?
    在Visual Studio 2012 中連接MySQL 資料來源在Visual Studio 2012 中MySQL 資料來源與實體框架(EF) 的整合一直是一個主題的討論。然而,在 DataSource Dialog 中新增 MySQL 資料庫給開發人員帶來了挑戰。 事實證明,MySQL Con...
    程式設計 發佈於2024-11-18

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3