Heim >Backend-Entwicklung >Python-Tutorial >Wie gehe ich mit Fehlern beim Senden von JSON-Daten von JavaScript an FastAPI um?

Wie gehe ich mit Fehlern beim Senden von JSON-Daten von JavaScript an FastAPI um?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-13 16:53:03969Durchsuche

How to Handle Errors When Sending JSON Data from JavaScript to FastAPI?

Fehlerbehandlung beim Posten von JSON-Daten von JavaScript an FastAPI

Um Daten von einem JavaScript-Frontend an ein FastAPI-Backend zu senden, müssen Sie sicherstellen, dass Daten werden im richtigen Format und an den entsprechenden Endpunkt übergeben. Wenn der Fehler 422 Unprocessable Entity auftritt, liegt dies wahrscheinlich an einer falschen Datenformatierung.

Abfrageparameter im Vergleich zu JSON-Parametern

Standardmäßig interpretiert FastAPI Funktionsparameter, die nicht im Pfad enthalten sind, als Abfrageparameter. Für JSON-Daten müssen Sie diese jedoch explizit mit einer der folgenden Methoden angeben:

1. Pydantic-Modell:

Definieren Sie ein Pydantic-Modell zur Darstellung der JSON-Datenstruktur:

from pydantic import BaseModel

class Item(BaseModel):
    eth_addr: str

@app.post('/ethAddress')
def add_eth_addr(item: Item):
    return item

2. Körpertyp:

Verwenden Sie den Körpertyp, um anzugeben, dass der Parameter aus dem Anforderungskörper analysiert werden soll:

from fastapi import Body

@app.post('/ethAddress')
def add_eth_addr(eth_addr: str = Body()):
    return {'eth_addr': eth_addr}

3. Body Embed:

Für einen einzelnen Body-Parameter können Sie das Argument „embed=True“ verwenden, um die Daten aus dem Anfragetext automatisch zu analysieren:

from fastapi import Body

@app.post('/ethAddress')
def add_eth_addr(eth_addr: str = Body(embed=True)):
    return {'eth_addr': eth_addr}

JavaScript Fetch API

Wenn Sie die Fetch-API in JavaScript zum Senden von JSON-Daten verwenden, müssen Sie den Content-Type-Header auf application/json setzen und die Daten im Text angeben Feld:

fetch("http://localhost:8000/ethAddress", {
  method: "POST",
  headers: {
    'Accept': 'application/json',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    "eth_addr": "some address"
  }),
});

Zusätzliche Ressourcen

Weitere Informationen und detaillierte Beispiele finden Sie in der folgenden Dokumentation und Ressourcen:

  • [FastAPI JSON Request and Response] (https://fastapi.tiangolo.com/tutorial/body/)
  • [Senden von JSON-Daten mit POST-Anfragen in JavaScript](https://stackoverflow.com/questions/44832885/sending-json-data-with-post-requests-in-javascript)
  • [POST-Anfrage mit JSON-Inhalt in JavaScript mit Fetch API](https://stackoverflow.com/questions/55749929/post-request-with-json-content-in-javascript-using-fetch-api)

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Fehlern beim Senden von JSON-Daten von JavaScript an FastAPI um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn