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

Servlets/JSP Java Discussion :

Compter le nombre d'essais de login


Sujet :

Servlets/JSP Java

  1. #1
    Membre à l'essai
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut Compter le nombre d'essais de login
    Bonjour,
    dans le cadre d'une application WEB développée avec Struts et hébergée sous Tomcat, je dois gérer plusieurs règles de sécurité que j'explique ci-dessous :
    - Pour le login, si un utilisateur se trompe 3 fois de login, je dois désactiver son accès pendant un temps à déterminer.
    - Dans l'application, si un utilisateur se trompe 3 fois dans la saisie d'un champ particulier du formulaire, idem je dois désactiver son accès.

    Comment gérer ça au niveau de mon application ?
    - Je pourrais gérer une HashMap globale avec l'IP come clé, et le nb essais comme valeur, mais bon je trouve ça pas très propre.
    - Je pourrais enregistrer les data en base mais j'ai peur pour les performances...

    Avez vous des bonnes pratiques pour cette problèmatique de sécurité ?
    Est-ce que Tomcat peut faire ça par config ? sinon une idée côté programmation ?

    Merci
    jsl1

  2. #2
    Membre à l'essai
    Inscrit en
    Mars 2006
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 9
    Points : 11
    Points
    11
    Par défaut
    Bonjour,
    pour ton login si tu utilises struts pourquoi ne pas mettre dans ton formulaire un compteur qui s'incrémente dans ta méthode validate?
    A partir du moment ou l'utilisateur est blocké tu mets dans une hashMap static son login et l'heure à laquelle il a été bloqué. A sa prochaine connection tu testeras si il a le droit d'etre débloqué, et si oui tu le supprime de la hashMap.

    Attention tout de même, si tu es amené a redémarrer ton application, tous les comptes seront débloqués.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    365
    Détails du profil
    Informations personnelles :
    Localisation : Maroc

    Informations forums :
    Inscription : Janvier 2006
    Messages : 365
    Points : 495
    Points
    495
    Par défaut
    Bonjour !
    Simple avis personnel. Au-delà des aspects techniques pour trouver la meilleure façon d'implémenter une solution à cette problématique, je m'interroge tout de même sur la pertinence du fait de devoir bloquer le compte d'un utilisateur pour cause de tentatives de login échouées. C'est vrai que ça pourrait permettre de ne pas mobiliser le serveur inutilement après un certain nombre d'essais, mais comme nous sommes sur un réseau public, n'importe qui pourrait le faire sur le compte de quelqu'un d'autre et le faire bloquer juste pour emmerder l'autre. Et comment faire la distinction quand la vraie personne tentera de se connecter ? Mais bon.... il y a surement une bonne raison pour que vous envisagiez quand même la nécessité de devoir bloquer des comptes utilisateur...
    SCJP 5 / SCBCD 1.3 Certified

  4. #4
    Membre chevronné
    Homme Profil pro
    Dév. Java & C#
    Inscrit en
    Octobre 2002
    Messages
    1 413
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Dév. Java & C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 413
    Points : 1 993
    Points
    1 993
    Par défaut
    Commentaire:

    +1 pour manblaizo

    Attention certaines entreprises utilisent un gateway pour aller sur internet et tous les connectés ont la même adresse IP.
    Bien le bonjour chez vous
    Jowo

  5. #5
    Membre à l'essai
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    Merci pour ces réponses constructives !

    Pour la HashMap, c'est justement l'utilisation d'une variable statique qui me plait pas, pê à tort.

    L'idée de base n'est pas de bloquer le simple utilisateur qui se trompe 3 fois mais d'éviter des attaques répetées. Je ne sais pas si c'est le meilleur moyen mais c'est une idée qui a été évoquée. Si vous connaissez d'autres moyens, ça m'interressent !

    Pour l'autre point, pas de soucis, les utilisateurs ne sont pas derrière une gateway.

  6. #6
    Membre à l'essai
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    D'ailleurs est ce possible de gérer dynamiquement le fait de bloquer une IP au niveau du serveur càd que le serveur rejette toutes les requêtes de cette IP ?

  7. #7
    Membre confirmé
    Avatar de bmoussaud
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    218
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2003
    Messages : 218
    Points : 555
    Points
    555
    Par défaut
    Dans le serveur J2EE BEA - Weblogic Server, il existe un mécanisme permettant de régler le nombre de tentative de connexion et le temps d'inactivité du compte. En revanche rien pour la saisie d'un champs particulier, cela restera un développement spécifique
    Benoit Moussaud - XebiaLabs - Automatisation des déploiements. Screencast & Demo

  8. #8
    Membre à l'essai
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    Merci ms le pb c'est que l'on va utiliser Tomcat.
    Pour préciser le contexte le serveur d'appli sera dans une DMZ, la BD dans le réseau interne.

Discussions similaires

  1. Comment compter le nombre de lettre identique ?
    Par divableue dans le forum ASP
    Réponses: 3
    Dernier message: 07/11/2003, 15h01
  2. Compter le nombre de page d'un report
    Par ToYonos dans le forum C++Builder
    Réponses: 4
    Dernier message: 17/06/2003, 09h36
  3. compter le nombre de record
    Par pram dans le forum XMLRAD
    Réponses: 2
    Dernier message: 12/03/2003, 09h53
  4. [TListView] Compter le nombre de lignes
    Par agh dans le forum Composants VCL
    Réponses: 2
    Dernier message: 30/09/2002, 20h25
  5. Compter le nombre ligne listée (COUNT) ?
    Par StouffR dans le forum Langage SQL
    Réponses: 7
    Dernier message: 02/09/2002, 09h41

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