Heim > Web-Frontend > js-Tutorial > Beispiele für den Upload und Download von Koa2-Dateien

Beispiele für den Upload und Download von Koa2-Dateien

小云云
Freigeben: 2018-03-30 09:26:42
Original
1927 Leute haben es durchsucht

In diesem Artikel werden hauptsächlich Beispiele für das Hoch- und Herunterladen von Koa2-Dateien vorgestellt, die in Webanwendungen immer noch relativ häufig vorkommen, unabhängig davon, ob es sich um Bilder oder andere Dateien usw. handelt. In Koa gibt es viele Middlewares, die uns helfen können, Funktionen schnell zu implementieren.

Datei-Upload

Wenn wir Dateien im Front-End hochladen, laden wir sie über Formulare hoch, und die hochgeladenen Dateien können nicht wie gewöhnliche Parameter im Front-End behandelt werden serverseitig Wird auch über ctx.request.body abgerufen. Wir können die Koa-Body-Middleware verwenden, um Datei-Uploads zu verarbeiten, die den Anfragetext in ctx.request einfügen kann.


// app.js
const koa = require('koa');
const app = new koa();
const koaBody = require('koa-body');

app.use(koaBody({
  multipart: true,
  formidable: {
    maxFileSize: 200*1024*1024 // 设置上传文件大小最大限制,默认2M
  }
}));

app.listen(3001, ()=>{
  console.log('koa is listening in 3001');
})
Nach dem Login kopieren

Nachdem Sie die Middleware verwendet haben, können Sie den hochgeladenen Dateiinhalt in ctx.request.body.files abrufen. Es muss darauf geachtet werden, maxFileSize festzulegen, andernfalls wird ein Fehler gemeldet, sobald die hochgeladene Datei das Standardlimit überschreitet.

Nach Erhalt der Datei müssen wir die Datei im Verzeichnis speichern und eine URL an das Frontend zurückgeben. Der Prozess im Knoten ist

  1. Erstellen Sie einen lesbaren Stream-Const-Reader = fs.createReadStream(file.path)

  2. Erstellen Sie einen beschreibbaren Stream-Const-Writer = fs.createWriteStream('upload/newpath.txt')

  3. Der lesbare Stream schreibt den beschreibbaren Stream über die Pipe reader.pipe(writer)


const router = require('koa-router')();
const fs = require('fs');

router.post('/upload', async (ctx){
 const file = ctx.request.body.files.file; // 获取上传文件
 const reader = fs.createReadStream(file.path); // 创建可读流
 const ext = file.name.split('.').pop(); // 获取上传文件扩展名
 const upStream = fs.createWriteStream(`upload/${Math.random().toString()}.${ext}`); // 创建可写流
 reader.pipe(upStream); // 可读流通过管道写入可写流
 return ctx.body = '上传成功';
})
Nach dem Login kopieren

Diese Methode eignet sich zum Hochladen von Bildern, Textdateien, komprimierten Dateien usw.

Datei-Download

koa-send ist eine statische Dateidienst-Middleware, die zur Implementierung der Datei-Download-Funktion verwendet werden kann.


const router = require('koa-router')();
const send = require('koa-send');

router.post('/download/:name', async (ctx){
 const name = ctx.params.name;
 const path = `upload/${name}`;
 ctx.attachment(path);
  await send(ctx, path);
})
Nach dem Login kopieren

Es gibt zwei Methoden zum Herunterladen im Frontend: window.open und Formularübermittlung. Hier wird das einfachere window.open verwendet.


<button onclick="handleClick()">立即下载</button>
<script>
 const handleClick = () => {
 window.open(&#39;/download/1.png&#39;);
 }
</script>
Nach dem Login kopieren

Das Standardfenster besteht darin, ein neues Fenster zu öffnen, zu blinken und dann zu schließen, was dem Benutzer kein gutes Erlebnis bietet. Sie können ein hinzufügen zweiter Parameter window.open('/download/1.png', '_self'); , dieser wird direkt im aktuellen Fenster heruntergeladen. Dadurch wird jedoch die aktuelle Seite durch die URL ersetzt, wodurch Seitenereignisse wie beforeunload ausgelöst werden. Wenn Ihre Seite auf dieses Ereignis lauscht und einige Vorgänge ausführt, hat dies Auswirkungen. Dann können Sie auch ein verstecktes Iframe-Fenster verwenden, um den gleichen Effekt zu erzielen.


<button onclick="handleClick()">立即下载</button>
<iframe name="myIframe" style="display:none"></iframe>
<script>
 const handleClick = () => {
 window.open(&#39;/download/1.png&#39;, &#39;myIframe&#39;);
 }
</script>
Nach dem Login kopieren

Batch-Download

Es gibt keinen Unterschied zwischen Batch-Download und Einzel-Download, führen Sie einfach ein paar weitere Downloads durch. Daran ist wirklich nichts auszusetzen. Wäre das Erlebnis nicht besser, wenn Sie so viele Dateien in ein komprimiertes Paket packen und dann nur dieses komprimierte Paket herunterladen würden?

Dateiverpackung

Archiver ist ein Modul, das eine plattformübergreifende Verpackungsfunktion in Node.js realisieren kann und ZIP- und TAR-Formate unterstützt.


const router = require(&#39;koa-router&#39;)();
const send = require(&#39;koa-send&#39;);
const archiver = require(&#39;archiver&#39;);

router.post(&#39;/downloadAll&#39;, async (ctx){
 // 将要打包的文件列表
 const list = [{name: &#39;1.txt&#39;},{name: &#39;2.txt&#39;}];
 const zipName = &#39;1.zip&#39;;
 const zipStream = fs.createWriteStream(zipName);
  const zip = archiver(&#39;zip&#39;);
  zip.pipe(zipStream);
 for (let i = 0; i < list.length; i++) {
 // 添加单个文件到压缩包
 zip.append(fs.createReadStream(list[i].name), { name: list[i].name })
 }
 await zip.finalize();
 ctx.attachment(zipName);
 await send(ctx, zipName);
})
Nach dem Login kopieren

Wenn Sie den gesamten Ordner direkt verpacken, müssen Sie nicht jede Datei durchlaufen und an das komprimierte Paket anhängen


const zipStream = fs.createWriteStream(&#39;1.zip&#39;);
const zip = archiver(&#39;zip&#39;);
zip.pipe(zipStream);
// 添加整个文件夹到压缩包
zip.directory(&#39;upload/&#39;);
zip.finalize();
Nach dem Login kopieren

Hinweis: Packen Sie den gesamten Ordner. Die generierte komprimierte Paketdatei kann nicht in diesem Ordner gespeichert werden, da sie sonst kontinuierlich gepackt wird.

Probleme mit der chinesischen Kodierung

Wenn der Dateiname Chinesisch enthält, können unerwartete Situationen auftreten. Wenn es also beim Hochladen chinesische Zeichen enthält, kodiere ich den Dateinamen mit encodeURI(), um ihn zu speichern, und entschlüssele ihn dann beim Herunterladen mit decodeURI().


ctx.attachment(decodeURI(path));
await send(ctx, path);
Nach dem Login kopieren

ctx.attachment Setzen Sie Content-Disposition auf „attachment“, um den Client anzuweisen, zum Download aufzufordern. Verwenden Sie den entschlüsselten Dateinamen als Namen der herunterzuladenden Datei, sodass beim lokalen Herunterladen weiterhin der chinesische Name angezeigt wird.

Im Quellcode von koa-send wird der Dateipfad jedoch mit decodeURIComponent() dekodiert:


// koa-send
path = decode(path)

function decode (path) {
 try {
  return decodeURIComponent(path)
 } catch (err) {
  return -1
 }
}
Nach dem Login kopieren

Zu diesem Zeitpunkt Nach der Dekodierung herunterladen Der Pfad enthält chinesische Zeichen und der codierte Pfad ist auf unserem Server gespeichert. Die entsprechende Datei kann natürlich nicht gefunden werden.

Um dieses Problem zu lösen, lassen Sie es nicht entschlüsseln. Wenn Sie den Koa-Send-Quellcode nicht berühren möchten, können Sie stattdessen eine andere Middleware-Koa-Sendfile verwenden.


const router = require(&#39;koa-router&#39;)();
const sendfile = require(&#39;koa-sendfile&#39;);

router.post(&#39;/download/:name&#39;, async (ctx){
 const name = ctx.params.name;
 const path = `upload/${name}`;
 ctx.attachment(decodeURI(path));
  await sendfile(ctx, path);
})
Nach dem Login kopieren

Verwandte Empfehlungen:

10 empfohlene Artikel über koa2

Tutorial zur Verwendung des koa2-Frameworks in nodejs6

Teilen Sie Beispiel-Tutorials zur Verwendung des koa2-Frameworks in nodejs

Das obige ist der detaillierte Inhalt vonBeispiele für den Upload und Download von Koa2-Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage