So stellen Sie eine Node.js Express-App auf Netlify bereit (4)
DDDOriginal
2024-11-10 10:57:021054Durchsuche
Netlify macht es nicht einfach, eine Express-Web-App zu hosten. Ich hoffe, dass Sie diesen Leitfaden nützlich finden.
Schritte
Strukturieren Sie Ihre App auf ähnliche Weise wie unten:
Folgen Sie dieser Anleitung https://docs.netlify.com/frameworks/express/ . Ich habe „node_bundler = „esbuild““ gelöscht, weil es einen ESM-Fehler ausgegeben hat und trotzdem alles einwandfrei funktioniert hat.
Behalten Sie beim Erstellen der Datei „netlify.toml“ die Weiterleitungen spezifisch für die API und alle Endpunkte bei, die Sie über Express bedienen möchten. Eine allgemeine Weiterleitung (z. B. „/*“) wird Ihr CDN und die statische Dateibereitstellung durcheinander bringen.
(Optional) Verwenden Sie eine lokale Serverdatei für die Entwicklung, um Dinge wie das Bild übersichtlicher zu halten:
In der index.html und den restlichen .html-Dateien wird der Pfad zu CSS, JS und anderen Assets am besten auf das CDN festgelegt, das sowohl in der Entwicklung als auch in der Produktion funktioniert, d. h.:
Lauf
Netlify-Entwickler
auf der Konsole zum Testen vor der Bereitstellung
Wichtige Lektionen
Die server.js- oder server.mjs-App hat nur Zugriff auf /netlify/functions. Der Ordner „public“, „dist“ oder „static“ wird nicht zum Netlify-Ordner hinzugefügt, es sei denn, er wird explizit in der Datei „netlify.toml“ mit dem Befehl angegeben
[functions]
included_files = [
"static/views/**" # Include all files in static/views for server-side access
]
Statische Assets werden besser durch das CDN von Netlify bedient, was automatisch geschieht, wenn Sie in der Datei netlify.toml den Befehl verwenden
[build]
publish = "static" # Static assets to be served by Netlify's CDN. Folder defaults to public
Console.log-Anweisungen außerhalb von Router-Endpunkten werden nicht auf der Konsole angezeigt.
Das obige ist der detaillierte Inhalt vonSo stellen Sie eine Node.js Express-App auf Netlify bereit (4). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
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