Maison > interface Web > js tutoriel > le corps du texte

Utilisation simple des sessions dans Nodejs et méthodes d'authentification via sessions_node.js

WBOY
Libérer: 2016-05-16 15:16:15
original
1388 Les gens l'ont consulté

La session n'a pas besoin d'être présentée, afin qu'un http puisse correspondre à un utilisateur final.

L'essence de la session est mise en œuvre à l'aide de cookies.

Le principe est probablement le suivant : http amène le serveur à paramétrer des cookies à l'avance, le serveur récupère le cookie indiquant l'identité de l'utilisateur, puis se rend à un emplacement fixe (base de données, fichier) pour récupérer l'identité de l'utilisateur correspondant. Attribuez l'identité à la demande de cette demande et l'identité de l'utilisateur sera connue lors du traitement du programme. (Il est automatiquement implémenté pour vous en PHP, ASP ou autres langages côté serveur)

Mettre en place des cookies

Un cookie qui identifie l'utilisateur doit être défini pour chaque utilisateur. Vous pouvez utiliser les règles suivantes

Valeur MD5 de l'adresse e-mail enregistrée, valeur MD5 du mot de passe et valeur MD5 du code aléatoire. (Juste un exemple, ce n'est peut-être pas une bonne solution)

Extrait de code du serveur :

res.setHeader("Set-Cookie", ["sid="+newUser.toCookie()+";path=/;domain="+config.domain+";expires="+new Date("2030") ]); 
Copier après la connexion

cookie

sid=275fccab7935736ff68c95c3ddbfaaee|275fccab7935736ff68c95c3ddbfaaee|275fccab7935736ff68c95c3ddbfaaee 
Copier après la connexion

Utiliser des cookies pour obtenir l'identité de l'utilisateur et configurer la session

Dirigez ici toutes les demandes de ressources non statiques pour traitement. Obtenez le cookie, divisez le cookie et trouvez des utilisateurs qualifiés dans la base de données. Enfin, utilisez next pour passer à la logique de requête suivante.

La logique de requête suivante consiste à utiliser directement req.session.user pour obtenir l'objet utilisateur.

session:function(req, res, next){
req.session = {};
if( req.cookies && req.cookies.sid ){
var a = req.cookies.sid.split("|");
var hexMail = a[0];
var hexPwd = a[1];
var hexRandom = a[2];
UserModel.hexFind(hexMail, hexPwd, hexRandom, function( status ){
//console.log("hexFind", status );
if(status.code == "0"){
//req.cookiesSelecter = cookiesSelecter;
req.session.user = status.result;
}
next();
});
}else{
next();
} 
}
Copier après la connexion

Permettez-moi de parler de la façon dont nodejs implémente l'authentification d'identité via une session

Authentification de session nodejs express

1) Module d'importation

var session = require('express-session');
var cookieParser = require('cookie-parser');
Copier après la connexion

2) Appliquer le cookie et la session

app.use(cookieParser());
app.use(session({
resave: true, // don't save session if unmodified
saveUninitialized: false, // don't create session until something stored
secret: 'love'
}));
Copier après la connexion

3) Lors de la demande, appliquez l'authentification

app.use(function(req,res,next){
if (!req.session.user) {
if(req.url=="/login"){
next();//如果请求的地址是登录则通过,进行下一个请求
}
else
{
res.redirect('/login');
}
} else if (req.session.user) {
next();
}
});
Copier après la connexion

4) Conception de connexion

app.get('/login',function(req,res){
res.render("login");
});
app.post('/login',function(req,res){
if(req.body.username=="love" && req.body.password=="love"){
var user = {'username':'love'};
req.session.user = user;
res.redirect('/admin/app/list');
}
else
{
res.redirect('/login');
}
});
app.get('/logout',function(req,res){
req.session.user = null;
res.redirect('/login');
});
Copier après la connexion
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!