Beim Erstellen einer Next.js-Website in der Produktion können Abruffehler auftreten, die beim Einlaufen nicht auftreten Entwicklungsmodus. Dies kann frustrierend und verwirrend sein.
Die Fehlermeldung „FetchError: ungültiger JSON-Antworttext bei ...“ weist häufig auf ein Problem mit der von Ihrer API-Route zurückgegebenen JSON-Antwort hin . Konkret deutet der Fehler „Unerwartetes Token T in JSON an Position 0“ darauf hin, dass der Server ungültige JSON-Daten zurückgibt.
Aufruf interner API-Routen
In Next.js ist es wichtig, den Aufruf interner API-Routen innerhalb von getStaticProps zu vermeiden. Interne API-Routen sind während der Build-Zeit nicht verfügbar, da der Server noch nicht gestartet wurde.
Lösung: Ersetzen Sie den API-Routenaufruf in getStaticProps durch direkten serverseitigen Code, der die erforderlichen Schritte ausführt Datenabruf.
Absolute URLs beim Abruf
Wenn Sie die entfernen assetPrefix aus next.config.js, stellen Sie sicher, dass die beim Abruf verwendeten URLs absolut sind. Relative URLs funktionieren möglicherweise nicht in Produktions-Builds.
Lösung:Ändern Sie die Abrufaufrufe, um absolute URLs zu verwenden.
Hier ist eine Umgestaltung Version Ihres Codes, die das vermeidet Fehler:
// pages/product/[slug] import db from '../../../data/products' // Remaining code... export const getStaticProps = async ({ params: { slug }, locale }) => { const result = db.filter(item => item.slug === slug); const data = result.filter(item => item.locale === locale)[0]; const { title, keywords, description } = data; return { props: { data, description, keywords, title, }, }; }; export const getStaticPaths = async () => { const paths = db.map(({ slug, locale }) => ({ params: { slug }, locale })); return { fallback: true, paths, }; };
Indem Sie die Ursachen von Abruffehlern während der Next.js-Produktions-Builds verstehen und die entsprechenden Lösungen anwenden, können Sie eine erfolgreiche Bereitstellung Ihrer statischen Website sicherstellen. Denken Sie daran, den Aufruf interner API-Routen in getStaticProps zu vermeiden, absolute URLs beim Abruf zu verwenden und direkten serverseitigen Code für den Datenabruf in Produktions-Builds zu bevorzugen.
Das obige ist der detaillierte Inhalt vonWarum erhalte ich beim Erstellen meiner statischen Next.js-Website-Produktion Abruffehler?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!