IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

NodeJS Discussion :

Session : détection de déconnection


Sujet :

NodeJS

  1. #1
    Membre averti
    Homme Profil pro
    etudiant info
    Inscrit en
    Mars 2016
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : etudiant info

    Informations forums :
    Inscription : Mars 2016
    Messages : 32
    Par défaut Session : détection de déconnection
    Bonjour,

    Je développe actuellement un site web avec NodeJS et j'aimerais savoir si il est possible de détecter la déconnexion d'une session utilisateur en récupérant par exemple l'ID de la session. Actuellement j'utilise express-session mais je peux changer si ça ne convient pas. Je crois avoir compris que cela est faisable avec le module SocketIO, mais je me demande si son utilisation serait pertinente simplement pour détecter les déconnexions.
    Je vous explicite un peu mon problème : Tant que la session est active, mon serveur stocke des fichiers pour cette session ; j'aimerais donc savoir, à un moment donnée, si la session existe toujours (si l'utilisateur n'a pas quitté son navigateur) car si elle n'existe plus, je supprime les fichiers.

    J'espère que j'ai été assez clair et je vous remercie d'avance pour votre aide !

  2. #2
    Expert confirmé
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 419
    Par défaut
    Ce n'est pas possible de faire ce que tu demandes, la session peut se terminer pour d'autres raisons sans qu'un évènement ne soit émis (crash du browser, crash de la machine du à une mémé qui creuse un trou dans le quartier ou tout autre impondérable).

    Le mieux c'est de supprimer les fichiers à la connexion d'un utilisateur, et d'avoir un démon qui passe le balais lorsque l'utilisateur ne s'est pas connecté depuis une durée à spécifier. Là tu es certain de passer dans tous les cas de figure (même la mémé qui creuse un trou).

    Sinon le top c'est de ne pas écrire de fichiers sur le filesystem (pas super scalable) mais d'enregistrer ces informations dans une base de données.

  3. #3
    Membre averti
    Homme Profil pro
    etudiant info
    Inscrit en
    Mars 2016
    Messages
    32
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : etudiant info

    Informations forums :
    Inscription : Mars 2016
    Messages : 32
    Par défaut
    Citation Envoyé par Marco46 Voir le message
    Le mieux c'est de supprimer les fichiers à la connexion d'un utilisateur, et d'avoir un démon qui passe le balais lorsque l'utilisateur ne s'est pas connecté depuis une durée à spécifier. Là tu es certain de passer dans tous les cas de figure (même la mémé qui creuse un trou).
    Merci de ta réponde Marco, dans la solution que tu envisages, il me semble que tu définis un utilisateur comme une entrée dans la base de données. Or, je n'ai pas de base de données et je n'ai pas de notion de compte dans l'application que je développe. C'est pour cela que ma notion d'utilisateur se limite à la session (les fichiers stockées sur mon serveur sont rattachés pour chaque utilisateur à l'ID de sa session). Si j'avais un moyen de savoir si un identifiant de session donné est actif, je pourrais mettre en place un démon.

  4. #4
    Expert confirmé
    Avatar de Marco46
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    4 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 4 419
    Par défaut
    Il te faut un fichier qui décrit la session, et dans cette session à chaque fois qu'une requête passe pour cette session tu mets à jour une donnée représentant le timestamp de dernière connexion.

    Ainsi ton démon peut faire son test sur cette valeur pour savoir s'il doit tout scratcher ou non.

    Ta session doit forcément être persistée, elle ne peut pas être en mémoire seulement. Sinon ça signifie que ton démon ne doit plus faire de check sur une date, mais tourner régulièrement et supprimer tous les fichiers qui ne sont pas rattachés à une session existante.

    Bon ceci dit je ne sais pas si on t'impose ce système de session mais c'est pas du tout scalable (comment tu fais pour gérer 2 instances de ton serveur derrière un répartiteur de charge ? Tu ne peux pas.).

    Autre point, avoir un système de session mais pas de gestion de compte utilisateur c'est vraiment mais alors vraiment super bizarre.

Discussions similaires

  1. Internet Explorer déconnecte la session tout seul
    Par Borowsky dans le forum Général Conception Web
    Réponses: 7
    Dernier message: 29/12/2009, 17h26
  2. Détection de session entre 2 tomcat
    Par chateau64 dans le forum Tomcat et TomEE
    Réponses: 2
    Dernier message: 14/06/2009, 22h17
  3. déconnecter une session en demandant confirmation.
    Par loopback dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 22/05/2008, 14h15
  4. Pb de sessions qui se déconnectent
    Par Wedge3D dans le forum ASP
    Réponses: 5
    Dernier message: 09/03/2006, 20h38
  5. Détection ouverture de session Windows
    Par Atao_29 dans le forum MFC
    Réponses: 9
    Dernier message: 18/03/2005, 16h49

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo