Koa.js - Objet de réponse

Un objet Koa Response est une abstraction au-dessus de l'objet de réponse vanille du nœud, fournissant des fonctionnalités supplémentaires utiles pour le développement de serveurs HTTP au quotidien. L'objet de réponse Koa est intégré dans l'objet de contexte,this. Déconnectons l'objet de réponse chaque fois que nous recevons une requête.

var koa = require('koa');
var router = require('koa-router');
var app = koa();

var _ = router();

_.get('/hello', getMessage);

function *getMessage(){
   this.body = 'Your request has been logged.';
   console.log(this.response);
}

app.use(_.routes());
app.listen(3000);

Lorsque vous exécutez ce code et accédez à https://localhost:3000/hello alors vous recevrez la réponse suivante.

Sur votre console, vous obtiendrez l'objet de requête déconnecté.

{ 
   status: 200,
   message: 'OK',
   header: 
   {
      'content-type': 'text/plain; charset=utf-8',
      'content-length': '12' 
   },
   body: 'Your request has been logged.' 
}

Le statut et le message sont automatiquement définis par Koa mais peuvent être modifiés par nos soins. Si nous ne définissons pas le corps de la réponse, le code d'état est défini sur 404. Une fois que nous avons défini le corps de la réponse, l'état est défini sur 200 par défaut. Nous pouvons explicitement remplacer ce comportement.

Nous avons accès à de nombreuses propriétés utiles de la réponse en utilisant cet objet. Regardons quelques exemples -

response.header

Fournit tous les en-têtes de réponse.

response.status

Fournit l'état de la réponse (200, 404, 500, etc.). Cette propriété est également utilisée pour définir l'état de la réponse.

response.message

Fournit le message de réponse. Cette propriété est également utilisée pour définir des messages personnalisés avec des réponses. Il est associé à response.status.

response.body

Obtenez ou définissez le corps de la réponse. Habituellement, nous y accédons à l'aide de l'objet context. C'est juste une autre façon d'y accéder. Le corps peut être du type: String, Buffer, Stream, Object ou Null.

response.type

Obtenez ou définissez le type de contenu de la réponse actuelle.

response.get (champ)

Cette fonction est utilisée pour obtenir les valeurs des en-têtes avec un champ de valeur insensible à la casse.

response.set (champ, valeur)

Cette fonction est utilisée pour définir un en-tête sur la réponse à l'aide d'une paire champ et valeur.

response.remove (champ)

Cette fonction est utilisée pour annuler un en-tête sur la réponse à l'aide d'un nom de champ.

Vous pouvez en savoir plus sur l'objet de réponse dans la documentation sur Response .