Koa.js - Authentification
L'authentification est un processus dans lequel les informations d'identification fournies sont comparées à celles enregistrées dans la base de données des informations des utilisateurs autorisés sur un système d'exploitation local ou dans un serveur d'authentification. Si les informations d'identification correspondent, le processus est terminé et l'utilisateur reçoit une autorisation d'accès.
Nous allons créer un système d'authentification très basique qui utilisera Basic HTTP Authentication. C'est le moyen le plus simple d'appliquer le contrôle d'accès car il ne nécessite pas de cookies, de sessions ou quoi que ce soit d'autre. Pour utiliser cela, le client doit envoyer l'en-tête d'autorisation avec chaque demande qu'il fait. Le nom d'utilisateur et le mot de passe ne sont pas chiffrés, mais sont concaténés en une seule chaîne comme la suivante.
username:password
Cette chaîne est codée avec Base64 et le mot Basic est placé avant cette valeur. Par exemple, si votre nom d'utilisateur est Ayush et votre mot de passe India, la chaîne"Ayush:India" serait envoyé tel que codé dans l'en-tête d'autorisation.
Authorization: Basic QXl1c2g6SW5kaWE=
Pour implémenter cela dans votre application koa, vous aurez besoin du middleware koa-basic-auth. Installez-le en utilisant -
$ npm install --save koa-basic-auth
Ouvrez maintenant votre fichier app.js et entrez le code suivant.
//This is what the authentication would be checked against
var credentials = { name: 'Ayush', pass: 'India' }
var koa = require('koa');
var auth = require('koa-basic-auth');
var _ = require('koa-router')();
var app = koa();
//Error handling middleware
app.use(function *(next){
try {
yield next;
} catch (err) {
if (401 == err.status) {
this.status = 401;
this.set('WWW-Authenticate', 'Basic');
this.body = 'You have no access here';
} else {
throw err;
}
}
});
// Set up authentication here as first middleware.
// This returns an error if user is not authenticated.
_.get('/protected', auth(credentials), function *(){
this.body = 'You have access to the protected area.';
yield next;
});
// No authentication middleware present here.
_.get('/unprotected', function*(next){
this.body = "Anyone can access this area";
yield next;
});
app.use(_.routes());
app.listen(3000);
Nous avons créé un middleware de gestion des erreurs pour gérer toutes les erreurs liées à l'authentification. Ensuite, nous avons créé 2 itinéraires -
/protected- Cette route n'est accessible que si l'utilisateur envoie l'en-tête d'authentification correct. Pour tous les autres, cela donnera une erreur.
/unprotected - Cette route est accessible à tous, avec ou sans authentification.
Maintenant, si vous envoyez une demande à / protected sans en-tête d'authentification ou avec les mauvaises informations d'identification, vous recevrez une erreur. Par exemple,
$ curl https://localhost:3000/protected
Vous recevrez la réponse comme -
HTTP/1.1 401 Unauthorized
WWW-Authenticate: Basic
Content-Type: text/plain; charset=utf-8
Content-Length: 28
Date: Sat, 17 Sep 2016 19:05:56 GMT
Connection: keep-alive
Please authenticate yourself
Cependant, avec les bonnes informations d'identification, vous obtiendrez la réponse attendue. Par exemple,
$ curl -H "Authorization: basic QXl1c2g6SW5kaWE=" https://localhost:3000/protected -i
Vous obtiendrez la réponse comme -
HTTP/1.1 200 OK
Content-Type: text/plain; charset=utf-8
Content-Length: 38
Date: Sat, 17 Sep 2016 19:07:33 GMT
Connection: keep-alive
You have access to the protected area.
L'itinéraire / non protégé est toujours accessible à tous.