Heim Web-Frontend js-Tutorial React & Expo – So laden Sie Dateien hoch und herunterladen

React & Expo – So laden Sie Dateien hoch und herunterladen

Dec 16, 2024 am 12:30 AM

Einführung

Es fiel mir schwer, klare Beispiele für das Hoch- und Herunterladen von Dateien in einer Expo-basierten mobilen App zu finden. Um anderen zu helfen, die vor der gleichen Herausforderung stehen – oder einfach nur Neugierigen –, habe ich diesen Beitrag geschrieben.

Unterwegs werden wir Schlüsselkonzepte erkunden, deren Verständnis wertvoll ist:

  • Puffer
  • Absichtsfilter
  • MIME-Typen
  • Anwendung/Oktett-Stream
  • multipart/form-data
  • Und mehr...

Was wir behandeln werden:

  • Senden und Empfangen von Dateien mit einem Fastify-Server.
  • Hochladen, Herunterladen und Anzeigen von Dateien in einer React-Web-App.
  • Dateien hochladen, herunterladen und in einer mobilen React Native (Expo)-App anzeigen.

Der gesamte Code und die Postman-Sammlung sind in meinem GitHub verfügbar.

Server

React & Expo - How to Upload & Download Files

Der Server läuft auf Fastify (einer modernisierten Version von Express.js). Um die App zu starten, gehen Sie wie folgt vor:

  1. Navigieren Sie mit dem Terminal zu /server
  2. Installieren Sie die Abhängigkeiten mit npm install
  3. Führen Sie den Server mit npm run dev aus

In app.js haben wir drei wichtige Endpunkte:

- Endpunkt herunterladen (/download)

fastify.get("/download", async function handler(_, reply) {
  const fd = await open(FILE_TO_DOWNLOAD);
  const stream = fd.createReadStream();

  const mimeType = mime.lookup(FILE_TO_DOWNLOAD);

  console.log(`Downloading -> ${FILE_TO_DOWNLOAD}`);

  return reply
    .type(mimeType)
    .header(
      "Content-Disposition",
      `attachment; filename=${path.basename(FILE_TO_DOWNLOAD)}`
    )
    .send(stream);
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Dieser Endpunkt sendet example.webp als Stream mit createReadStream(). Der MIME-Typ ist enthalten, damit der Client weiß, wie er mit der Datei umgehen soll. Zum Beispiel.webp ist dies image/webp.

?Hinweis: Der MIME-Typ definiert das Format der gesendeten Datei. Dies hilft dem Client, es korrekt anzuzeigen.
Weitere MIME-Typen anzeigen.

Der Content-Disposition-Header definiert, wie der Inhalt dem Kunden präsentiert werden soll. Inklusive Anhang; Dateiname= fordert den Browser auf, die Datei herunterzuladen, anstatt sie inline anzuzeigen. Um es direkt anzuzeigen, verwenden Sie Inline statt Anhang.
Erfahren Sie mehr über Content-Disposition

React & Expo - How to Upload & Download Files

- Laden Sie Multiples-Dateien mit Formulardaten hoch (/upload-multiples)

fastify.post("/upload-multiples", async function handler(request) {
  const parts = request.files();
  const uploadResults = [];

  for await (const file of parts) {
    const fileBuffer = await file.toBuffer();
    const filename = file.filename;
    const filePath = path.join(DIR_TO_UPLOAD, filename);

    await writeFile(filePath, fileBuffer);
    uploadResults.push({ filename, uploaded: true });
    console.log(`Uploaded -> ${filePath}`);
  }

  return { uploadedFiles: uploadResults };
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Dieser Endpunkt akzeptiert eine mehrteilige/Formulardatenanfrage. Es:

  1. Ruft die Dateien aus der Anfrage ab.
  2. Konvertiert jede Datei in einen Puffer (eine JavaScript-Darstellung von Binärdaten).
  3. Speichert die Datei im Verzeichnis /upload.

Eine Anfrage könnte beispielsweise so aussehen:

React & Expo - How to Upload & Download Files

- Hochladen von Dateien mit Octet Stream (/upload-octet-stream)

fastify.get("/download", async function handler(_, reply) {
  const fd = await open(FILE_TO_DOWNLOAD);
  const stream = fd.createReadStream();

  const mimeType = mime.lookup(FILE_TO_DOWNLOAD);

  console.log(`Downloading -> ${FILE_TO_DOWNLOAD}`);

  return reply
    .type(mimeType)
    .header(
      "Content-Disposition",
      `attachment; filename=${path.basename(FILE_TO_DOWNLOAD)}`
    )
    .send(stream);
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Dieser Endpunkt erwartet eine einzelne Binärdatei im Anforderungstext (Anwendung/Oktett-Stream). Im Gegensatz zu Multipart/Form-Data handelt es sich bei der Datei bereits um Binärdaten, sodass wir sie direkt auf die Festplatte schreiben können.

Die Anfrage sieht in Postman in etwa so aus:

React & Expo - How to Upload & Download Files

React & Expo - How to Upload & Download Files

Web (Reagieren)



React & Expo - How to Upload & Download Files

So führen Sie die App aus:

  1. Navigieren Sie mit dem Terminal zu /web
  2. Installieren Sie die Abhängigkeiten mit npm install
  3. Starten Sie die App mit npm run dev

Alle Funktionen für die Webanwendung sind in App.tsx enthalten:

React & Expo - How to Upload & Download Files

Diese React-App bietet drei Hauptfunktionen:

- Datei herunterladen/anzeigen

fastify.post("/upload-multiples", async function handler(request) {
  const parts = request.files();
  const uploadResults = [];

  for await (const file of parts) {
    const fileBuffer = await file.toBuffer();
    const filename = file.filename;
    const filePath = path.join(DIR_TO_UPLOAD, filename);

    await writeFile(filePath, fileBuffer);
    uploadResults.push({ filename, uploaded: true });
    console.log(`Uploaded -> ${filePath}`);
  }

  return { uploadedFiles: uploadResults };
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Wenn der Benutzer auf die Schaltfläche „Herunterladen“ klickt, wird die App:

  1. Ruft den /download-Endpunkt auf.
  2. Empfangt die Datei als binären Blob.
  3. Erstellt eine Objekt-URL aus dem Blob, die als temporäre URL fungiert, auf die der Browser zugreifen kann.

Das Verhalten hängt vom vom Server zurückgegebenen Content-Disposition-Header ab:

  • Wenn Content-Disposition Inline enthält, wird die Datei in einem neuen Tab angezeigt.
  • Wenn ein Anhang enthalten ist, wird die Datei automatisch heruntergeladen.

Um den Download auszulösen, erstellt die App ein temporäres Element, wobei der href auf die Objekt-URL festgelegt ist, und klickt programmgesteuert darauf, wodurch eine Benutzer-Download-Aktion simuliert wird.

- Datei mit Formulardaten hochladen

fastify.post("/upload-octet-stream", async function handler(request) {
  const filename = request.headers["x-file-name"] ?? "unknown.text";

  const data = request.body;
  const filePath = path.join(DIR_TO_UPLOAD, filename);

  await writeFile(filePath, data);

  return { uploaded: true };
});
Nach dem Login kopieren
Nach dem Login kopieren

Wenn auf die Schaltfläche „Datei hochladen“ geklickt wird:

  1. Die Funktion „uploadFile“ wird ausgeführt und erstellt eine versteckte Element und Simulation eines Benutzerklicks.
  2. Sobald der Benutzer eine oder mehrere Dateien auswählt, werden diese Dateien an ein FormData-Objekt angehängt.
  3. Die Anfrage wird an den Endpunkt /upload-multiples gesendet, der Dateien über multipart/form-data akzeptiert.

Dadurch kann der Server die hochgeladenen Dateien ordnungsgemäß verarbeiten und speichern.

- Laden Sie Dateien mit Octet Stream hoch

  const downloadFile = async () => {
    const response = await fetch(DOWNLOAD_API);

    if (!response.ok) throw new Error("Failed to download file");

    const blob = await response.blob();

    const contentDisposition = response.headers.get("Content-Disposition");

    const isInline = contentDisposition?.split(";")[0] === "inline";
    const filename = contentDisposition?.split("filename=")[1];

    const url = window.URL.createObjectURL(blob);

    if (isInline) {
      window.open(url, "_blank");
    } else {
      const a = document.createElement("a");
      a.href = url;
      a.download = filename || "file.txt";
      a.click();
    }

    window.URL.revokeObjectURL(url);
  };
Nach dem Login kopieren
Nach dem Login kopieren

Dieser Ansatz ist einfacher als die Verwendung von Multipart-/Formulardaten – senden Sie die Datei einfach direkt im Anforderungstext als Binärdaten und fügen Sie den Dateinamen in die Anforderungsheader ein.

Mobil (Messe)



React & Expo - How to Upload & Download Files

Sie können die App wie folgt starten:

  1. Navigieren Sie zum mobilen Verzeichnis in Ihrem Terminal.
  2. Installieren Sie die Abhängigkeiten: npm install
  3. Führen Sie das Projekt mit npm run android oder npm run ios aus

Die Hauptlogik befindet sich in App.tsx, wo Folgendes gerendert wird:

fastify.get("/download", async function handler(_, reply) {
  const fd = await open(FILE_TO_DOWNLOAD);
  const stream = fd.createReadStream();

  const mimeType = mime.lookup(FILE_TO_DOWNLOAD);

  console.log(`Downloading -> ${FILE_TO_DOWNLOAD}`);

  return reply
    .type(mimeType)
    .header(
      "Content-Disposition",
      `attachment; filename=${path.basename(FILE_TO_DOWNLOAD)}`
    )
    .send(stream);
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Um die Datei in einer neuen Ansicht anzuzeigen (z. B. wenn der Browser die Datei in einem neuen Tab öffnet), müssen wir die Antwort als Blob lesen und sie dann mit FileReader in Base64 umwandeln.

Wir schreiben die Datei in das Cache-Verzeichnis (ein privates Verzeichnis, auf das nur die App Zugriff hat) und zeigen sie dann mit IntentLauncher oder Sharing an, wenn der Benutzer iOS verwendet.

- Datei herunterladen

fastify.post("/upload-multiples", async function handler(request) {
  const parts = request.files();
  const uploadResults = [];

  for await (const file of parts) {
    const fileBuffer = await file.toBuffer();
    const filename = file.filename;
    const filePath = path.join(DIR_TO_UPLOAD, filename);

    await writeFile(filePath, fileBuffer);
    uploadResults.push({ filename, uploaded: true });
    console.log(`Uploaded -> ${filePath}`);
  }

  return { uploadedFiles: uploadResults };
});
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Dies ähnelt dem Webprozess, aber wir müssen den Blob mit FileReader als Base64 lesen und dann um Erlaubnis bitten, die Datei dort herunterzuladen, wo der Benutzer sie speichern möchte.

- Datei mit Formulardaten hochladen

fastify.post("/upload-octet-stream", async function handler(request) {
  const filename = request.headers["x-file-name"] ?? "unknown.text";

  const data = request.body;
  const filePath = path.join(DIR_TO_UPLOAD, filename);

  await writeFile(filePath, data);

  return { uploaded: true };
});
Nach dem Login kopieren
Nach dem Login kopieren

Verwenden Sie DocumentPicker, um Benutzern die Auswahl von Dateien zu ermöglichen, und verwenden Sie dann FormData, um die ausgewählten Dateien an die Anfrage anzuhängen. Der Vorgang ist sehr unkompliziert.

- Datei als Oktett-Stream hochladen

  const downloadFile = async () => {
    const response = await fetch(DOWNLOAD_API);

    if (!response.ok) throw new Error("Failed to download file");

    const blob = await response.blob();

    const contentDisposition = response.headers.get("Content-Disposition");

    const isInline = contentDisposition?.split(";")[0] === "inline";
    const filename = contentDisposition?.split("filename=")[1];

    const url = window.URL.createObjectURL(blob);

    if (isInline) {
      window.open(url, "_blank");
    } else {
      const a = document.createElement("a");
      a.href = url;
      a.download = filename || "file.txt";
      a.click();
    }

    window.URL.revokeObjectURL(url);
  };
Nach dem Login kopieren
Nach dem Login kopieren

Das Hochladen als Anwendung/Oktett-Stream ist noch einfacher als die Verwendung von FormData: Legen Sie die Header mit den Dateidetails und dem Inhaltstyp fest, fügen Sie dann die Datei zum Anforderungstext hinzu und fertig!

Abschluss

Es kann etwas verwirrend sein, wie man Dateien zwischen Plattformen anzeigt, herunterlädt und hochlädt. In diesen Beiträgen haben wir die häufigsten gesehen.

Ich hoffe, Ihnen geholfen zu haben?

Fallow me on @twitter

Das obige ist der detaillierte Inhalt vonReact & Expo – So laden Sie Dateien hoch und herunterladen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser 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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1664
14
PHP-Tutorial
1267
29
C#-Tutorial
1239
24
Entmystifizieren JavaScript: Was es tut und warum es wichtig ist Entmystifizieren JavaScript: Was es tut und warum es wichtig ist Apr 09, 2025 am 12:07 AM

JavaScript ist der Eckpfeiler der modernen Webentwicklung. Zu den Hauptfunktionen gehören eine ereignisorientierte Programmierung, die Erzeugung der dynamischen Inhalte und die asynchrone Programmierung. 1) Ereignisgesteuerte Programmierung ermöglicht es Webseiten, sich dynamisch entsprechend den Benutzeroperationen zu ändern. 2) Die dynamische Inhaltsgenerierung ermöglicht die Anpassung der Seiteninhalte gemäß den Bedingungen. 3) Asynchrone Programmierung stellt sicher, dass die Benutzeroberfläche nicht blockiert ist. JavaScript wird häufig in der Webinteraktion, der einseitigen Anwendung und der serverseitigen Entwicklung verwendet, wodurch die Flexibilität der Benutzererfahrung und die plattformübergreifende Entwicklung erheblich verbessert wird.

Die Entwicklung von JavaScript: Aktuelle Trends und Zukunftsaussichten Die Entwicklung von JavaScript: Aktuelle Trends und Zukunftsaussichten Apr 10, 2025 am 09:33 AM

Zu den neuesten Trends im JavaScript gehören der Aufstieg von Typenkripten, die Popularität moderner Frameworks und Bibliotheken und die Anwendung der WebAssembly. Zukunftsaussichten umfassen leistungsfähigere Typsysteme, die Entwicklung des serverseitigen JavaScript, die Erweiterung der künstlichen Intelligenz und des maschinellen Lernens sowie das Potenzial von IoT und Edge Computing.

JavaScript -Engines: Implementierungen vergleichen JavaScript -Engines: Implementierungen vergleichen Apr 13, 2025 am 12:05 AM

Unterschiedliche JavaScript -Motoren haben unterschiedliche Auswirkungen beim Analysieren und Ausführen von JavaScript -Code, da sich die Implementierungsprinzipien und Optimierungsstrategien jeder Engine unterscheiden. 1. Lexikalanalyse: Quellcode in die lexikalische Einheit umwandeln. 2. Grammatikanalyse: Erzeugen Sie einen abstrakten Syntaxbaum. 3. Optimierung und Kompilierung: Generieren Sie den Maschinencode über den JIT -Compiler. 4. Führen Sie aus: Führen Sie den Maschinencode aus. V8 Engine optimiert durch sofortige Kompilierung und versteckte Klasse.

Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Python vs. JavaScript: Die Lernkurve und Benutzerfreundlichkeit Apr 16, 2025 am 12:12 AM

Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

JavaScript: Erforschung der Vielseitigkeit einer Websprache JavaScript: Erforschung der Vielseitigkeit einer Websprache Apr 11, 2025 am 12:01 AM

JavaScript ist die Kernsprache der modernen Webentwicklung und wird für seine Vielfalt und Flexibilität häufig verwendet. 1) Front-End-Entwicklung: Erstellen Sie dynamische Webseiten und einseitige Anwendungen durch DOM-Operationen und moderne Rahmenbedingungen (wie React, Vue.js, Angular). 2) Serverseitige Entwicklung: Node.js verwendet ein nicht blockierendes E/A-Modell, um hohe Parallelitäts- und Echtzeitanwendungen zu verarbeiten. 3) Entwicklung von Mobil- und Desktop-Anwendungen: Die plattformübergreifende Entwicklung wird durch reaktnative und elektronen zur Verbesserung der Entwicklungseffizienz realisiert.

So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration) So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration) Apr 11, 2025 am 08:22 AM

Dieser Artikel zeigt die Frontend -Integration mit einem Backend, das durch die Genehmigung gesichert ist und eine funktionale edtech SaaS -Anwendung unter Verwendung von Next.js. erstellt. Die Frontend erfasst Benutzerberechtigungen zur Steuerung der UI-Sichtbarkeit und stellt sicher, dass API-Anfragen die Rollenbasis einhalten

Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration) Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration) Apr 11, 2025 am 08:23 AM

Ich habe eine funktionale SaaS-Anwendung mit mehreren Mandanten (eine EdTech-App) mit Ihrem täglichen Tech-Tool erstellt und Sie können dasselbe tun. Was ist eine SaaS-Anwendung mit mehreren Mietern? Mit Multi-Tenant-SaaS-Anwendungen können Sie mehrere Kunden aus einem Sing bedienen

Von C/C nach JavaScript: Wie alles funktioniert Von C/C nach JavaScript: Wie alles funktioniert Apr 14, 2025 am 12:05 AM

Die Verschiebung von C/C zu JavaScript erfordert die Anpassung an dynamische Typisierung, Müllsammlung und asynchrone Programmierung. 1) C/C ist eine statisch typisierte Sprache, die eine manuelle Speicherverwaltung erfordert, während JavaScript dynamisch eingegeben und die Müllsammlung automatisch verarbeitet wird. 2) C/C muss in den Maschinencode kompiliert werden, während JavaScript eine interpretierte Sprache ist. 3) JavaScript führt Konzepte wie Verschlüsse, Prototypketten und Versprechen ein, die die Flexibilität und asynchrone Programmierfunktionen verbessern.

See all articles