Koa.js - Téléchargement de fichiers
Les applications Web doivent fournir la fonctionnalité permettant les téléchargements de fichiers. Voyons comment nous pouvons recevoir des fichiers des clients et les stocker sur notre serveur.
Nous avons déjà utilisé le middleware koa-body pour analyser les requêtes. Ce middleware est également utilisé pour gérer les téléchargements de fichiers. Créons un formulaire qui nous permet de télécharger des fichiers puis de sauvegarder ces fichiers en utilisant Koa. Créez d'abord un modèle nomméfile_upload.pug avec le contenu suivant.
html
head
title File uploads
body
form(action = "/upload" method = "POST" enctype = "multipart/form-data")
div
input(type = "text" name = "name" placeholder = "Name")
div
input(type = "file" name = "image")
div
input(type = "submit")
Notez que vous devez donner le même type d'encodage que ci-dessus dans votre formulaire. Maintenant, traitons ces données sur notre serveur.
var koa = require('koa');
var router = require('koa-router');
var bodyParser = require('koa-body');
var app = koa();
//Set up Pug
var Pug = require('koa-pug');
var pug = new Pug({
viewPath: './views',
basedir: './views',
app: app
});
//Set up body parsing middleware
app.use(bodyParser({
formidable:{uploadDir: './uploads'}, //This is where the files would come
multipart: true,
urlencoded: true
}));
var _ = router(); //Instantiate the router
_.get('/files', renderForm);
_.post('/upload', handleForm);
function * renderForm(){
this.render('file_upload');
}
function *handleForm(){
console.log("Files: ", this.request.body.files);
console.log("Fields: ", this.request.body.fields);
this.body = "Received your data!"; //This is where the parsed request is stored
}
app.use(_.routes());
app.listen(3000);
Lorsque vous exécutez cela, vous obtenez le formulaire suivant.
Lorsque vous soumettez ceci, votre console produira la sortie suivante.
Les fichiers qui ont été téléchargés sont stockés dans le chemin dans la sortie ci-dessus. Vous pouvez accéder aux fichiers de la demande en utilisantthis.request.body.files et les champs de cette demande par this.request.body.fields.