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
.