Envoi d'une réponse de Koa

La traduction de l'article a été préparée en prévision du début du cours de développement Node.js






Koa est un petit framework qui vous permet de créer des applications backend qui s'exécutent sur le Node.js



.





Dans cet article, nous verrons comment envoyer différents types de réponses à l'aide de Koa.





Expédition du corps

Vous pouvez définir l'attribut body pour envoyer le corps de la réponse ctx



. Par exemple, nous pouvons envoyer le corps de la réponse comme ceci:





const Koa = require('koa');
const app = new Koa();
app.use(async (ctx, next) => {  
  ctx.body = 'foo';
});
app.listen(3000);
      
      



Dans le code ci-dessus, nous définissons la propriété ctx.body



sur «foo». C'est donc ce que nous obtenons lorsque nous accédons à l'adresse en /



utilisant notre navigateur ou en faisons une demande à l'aide d'un client HTTP.





En-tête d'envoi de la réponse

Nous pouvons envoyer des réponses dans notre code Koa en définissant la propriété ctx.response



. Pour définir l'en-tête, nous pouvons définir l'en-tête de réponse à l'aide du ctx.set



. Par exemple, nous pouvons l'utiliser comme ceci:





const app = new Koa();
app.use(async (ctx, next) => {
  ctx.set('Access-Control-Allow-Origin', '*');
  ctx.set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept');
  ctx.set('Access-Control-Allow-Methods', 'POST, GET, PUT, DELETE, OPTIONS');
  ctx.body = 'hello';
});
app.listen(3000);
      
      



Dans le code ci - dessus, nous appelons ctx.set



pour l'installation de différents titres, y compris le titre: Access-Control-Allow-Origin



, Access-Control-Allow-Headers



et Access-Control-Allow-Methods



.





/



, HTTP , Chrome Postman.





, respondbse.status



.





, :





const Koa = require('koa');
const app = new Koa();
app.use(async (ctx, next) => {
  ctx.status = 202;
  ctx.body = 'accepted';
});
app.listen(3000);
      
      



ctx.status 's 202. , / , 202 .





, , :





200 - OK







201 - created -







202 - accepted -







203 - non-authoritative information-







204 -  no content-







301 - moved permanently -







302 - found -







303 - see other - .







307 - temporary redirect -







308 - permanent redirect -







400 -  bad request -







401 -  unauthorized -







403 - forbidden-







404 - not found -







405 - method not allowed-







406 - not acceptable-







422 - unprocessable entity -







500 - internal server error-







501 - not implemented-







502 - bad gateway-







504 - gateway timeout-







(Headers)

ctx.response.lastModified



.





, :





const Koa = require('koa');
const app = new Koa();
app.use(async (ctx, next) => {
  ctx.response.lastModified = new Date(2020, 0, 1);
  ctx.body = 'foo';
});
app.listen(3000);
      
      



lastModified



1 2020 , , /



, Last-Modified



Wed, 01 2020 00:00:00 GMT



.





Content-Type, ctx.type



. , :





const Koa = require('koa');
const app = new Koa();
app.use(async (ctx, next) => {
  ctx.type = 'text/plain; charset=utf-8';
  ctx.body = 'foo';
});
app.listen(3000);
      
      



:





ctx.type = 'text/plain; charset=utf-8';
      
      



Content-Type 'text/plain; charset=utf-8'



. Content-Type /



.





, ctx.append()



. 2 .





, :





const Koa = require('koa');
const app = new Koa();
app.use(async (ctx, next) => {
  ctx.append('a', 1);
  ctx.body = 'foo';
});
app.listen(3000);
      
      



ctx.append()



'a'



1.





, /



, A 1.





, ctx.append()



. , ctx.body



.





, ctx.status



.

















All Articles