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 :

Formulaire J2EE - Gestion utilisateur


Sujet :

Servlets/JSP Java

  1. #1
    Membre du Club
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Janvier 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 116
    Points : 63
    Points
    63
    Par défaut Formulaire J2EE - Gestion utilisateur
    Bonjour à tous,
    Débutant en Java/J2ee, je suis en train de développer une petite application simple destinée à la gestion de vente auto pour des clients.
    Le principe est simple, un client se connecte, il enregistre ses véhicules qui met à la vente.

    Mon problème est le suivant. J'ai beaucoup de mal à mettre en place une gestion d'utilisateur à partir du moment ou ce dernier se connecte, comment faire en sorte qu'il reste en cache sur une durée souhaitée etc...

    Voici mon code :
    Page d'accueil avec demande de connexion
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
     
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml"   
          xmlns:h="http://java.sun.com/jsf/html"
          xmlns:ui="http://java.sun.com/jsf/facelets"
          xmlns:pou="http://primefaces.org/ui">
     
        <h:head>
            <link href="style.css" rel="stylesheet" type="text/css" title="Theme" />
        </h:head>
     
        <h:body>
            <div id="connexion">
                <h:form>
                    <pou:growl id="connexionGrowl" showDetail="true" sticky="true"/>
     
                    <pou:panel id="connexionPanel" header="Connexion" styleClass="panel">
                        <h:panelGrid columns="4">
                            <h:outputLabel value="Profil"/>
                            <h:outputLabel value="Identifiant"/>
                            <h:outputLabel value="Mot de passe"/>
                            <h:outputLabel value="Connexion"/>
     
     
                            <h:outputLabel value=" Client" />
                            <pou:inputText value="#{client.identifiant}"/>
                            <pou:inputText value="#{client.mdp}"/>
                            <pou:commandButton id="clientButton" value="Connexion" actionListener="#{connectClient.connexionClient}" styleClass="button" action="accueilClient" update="connexionGrowl"/>
     
                            <h:outputLabel value=" Admin"/>
                            <pou:inputText value="#{connectClient.adminLogin}"/>
                            <pou:inputText value="#{connectClient.adminMdp}"/>
                            <pou:commandButton id="adminButton" value="Connexion" actionListener="#{connectClient.connexionAdmin}" update="connexionGrowl" styleClass="button"/>
     
                        </h:panelGrid>
                    </pou:panel>
     
                    <pou:panel id="nouveauClientPanel" header="Nouveau Client" styleClass="panel" toggleable="true">
                        <h:panelGrid columns="2">
                            <h:outputLabel value="S'enregistrer :"/>
                            <pou:commandButton id="newCustomerButton" value="Formulaire" styleClass="button"/>
     
                            <h:outputLabel value="Aide :"/>
                            <pou:commandButton id="helpButton" value="Contact" styleClass="button"/>
                        </h:panelGrid>
                </pou:panel>
                </h:form> 
            </div>
        </h:body>
    </html>
    Le managedBean qui gère cette connexion :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
     
    /*
     * To change this license header, choose License Headers in Project Properties.
     * To change this template file, choose Tools | Templates
     * and open the template in the editor.
     */
     
    package DTO;
     
    import DAO.ConnecBDD;
    import Models.Client;
    import java.io.Serializable;
    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.Statement;
    import javax.faces.application.FacesMessage;
    import javax.faces.context.FacesContext;
    import javax.faces.event.ActionEvent;
     
    /**
     *
     * @author FixeFred
     */
    public class connectClient implements Serializable {
     
        //Objet Client
        private Client client;
        private String adminLogin;
        private String adminMdp;
     
        //Connexion BDD
        protected static final Connection bdd = ConnecBDD.getInstance();
     
        private String etat = null;
     
        private Client clientTrouve ;
        /**
         * Creates a new instance of connectClient
         */
        public connectClient() {
        }
     
        //authentification client
        public void connexionClient(ActionEvent event){
            FacesContext context = FacesContext.getCurrentInstance();
     
            String sqlClient = "Select nom, prenom, adresse, code_postale, ville, telephone, mobile, mail, identifiant, mdp FROM client WHERE identifiant = '"+client.getIdentifiant()+"'";
            System.out.println(sqlClient);
            try{
                Statement state = this.bdd.createStatement();
                ResultSet rs = state.executeQuery(sqlClient);
                rs.first();
                setClientTrouve(new Client(rs.getString(1), rs.getString(2), rs.getString(3), rs.getInt(4), rs.getString(5), rs.getInt(6), rs.getInt(7), rs.getString(8), rs.getString(9), rs.getString(10)));
                rs.close();
            }catch(Exception e){
                System.out.println("Erreur authentification client : "+e.getMessage());
            }
     
            context.addMessage(null, new FacesMessage("Identifié", "Bonjour" +clientTrouve.getPrenom()));
        }
     
        //authentification admin
        public String connexionAdmin(){
     
            FacesContext context = FacesContext.getCurrentInstance();
            System.out.println("Identifiant admin : " +adminLogin);
            System.out.println("Mdp admin : " +adminMdp);
            if (adminLogin.equals("admin")&adminMdp.equals("admin")) {
                context.addMessage(null, new FacesMessage("Identifié", "Bonjour Admin"));
                setEtat("success");
     
            }else{
                context.addMessage(null, new FacesMessage("Erreur", "Réessayez"));
                setEtat("failed");
            }
            System.out.println(getEtat());
            return getEtat();    
        }
     
        /**
         * @return the client
         */
        public Client getClient() {
            return client;
        }
     
        /**
         * @param client the client to set
         */
        public void setClient(Client client) {
            this.client = client;
        }
     
        /**
         * @return the adminLogin
         */
        public String getAdminLogin() {
            return adminLogin;
        }
     
        /**
         * @param adminLogin the adminLogin to set
         */
        public void setAdminLogin(String adminLogin) {
            this.adminLogin = adminLogin;
        }
     
        /**
         * @return the adminMdp
         */
        public String getAdminMdp() {
            return adminMdp;
        }
     
        /**
         * @param adminMdp the adminMdp to set
         */
        public void setAdminMdp(String adminMdp) {
            this.adminMdp = adminMdp;
        }
     
        /**
         * @return the clientTrouve
         */
        public Client getClientTrouve() {
            return clientTrouve;
        }
     
        /**
         * @param clientTrouve the clientTrouve to set
         */
        public void setClientTrouve(Client clientTrouve) {
            this.clientTrouve = clientTrouve;
        }
     
        /**
         * @return the etat
         */
        public String getEtat() {
            return etat;
        }
     
        /**
         * @param etat the etat to set
         */
        public void setEtat(String etat) {
            this.etat = etat;
        }
     
    }
    Jusque là, aucun problème, j'accède ensuite à la page ou l'utilisateur pourra modifier ses informations et véhicule :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
     
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml"   
          xmlns:h="http://java.sun.com/jsf/html"
          xmlns:ui="http://java.sun.com/jsf/facelets"
          xmlns:pou="http://primefaces.org/ui">
     
        <h:body>
            <ui:composition template="commonBody.xhtml">
                <ui:define name="menu">
                    <h:form>
                        <pou:panel header="Bonjour #{connectClient.clientTrouve.prenom}" styleClass="panel" >                       
                            <pou:accordionPanel multiple="true" styleClass="accordionPanel">
                                <pou:tab title="Mes informations">
                                    <pou:commandButton id="modifClientButton" value="Changer mes identifiants" styleClass="button"/>
                                    <pou:commandButton id="supprClientButton" value="Supprimer mon compte" styleClass="button"/>
                                </pou:tab>
                                <pou:tab title="Mes véhicules">
                                    <pou:commandButton id="ajoutVehiculeButton" value="Ajouter un véhicule" styleClass="button"/>
                                    <pou:commandButton id="modifVehiculeButton" value="Modifier un véhicule" styleClass="button"/>
                                    <pou:commandButton id="supprVehiculeButton" value="Supprimer un véhicule" styleClass="button"/>
                                    <pou:commandButton id="listVehiculeButton" value="Lister les Véhicules" styleClass="button"/>
                                </pou:tab>
                                <pou:tab title="Autres">
                                    <pou:commandButton id="connectButton" value="Retour accueil" action="indexClient" styleClass="button"/>
                                </pou:tab>
                            </pou:accordionPanel>
                        </pou:panel>
                    </h:form>
                </ui:define>
     
                <ui:define name="content">
                    <h:form>
                        <pou:panel id="informationClientPanel" header="Informations de #{connectClient.clientTrouve.prenom} #{connectClient.clientTrouve.nom}" styleClass="panel">
                        <h:panelGrid columns="2">
                                    <h:outputLabel value="Nom : "/>
                                    <h:inputText id="out1" value="#{connectClient.clientTrouve.nom}"/>
     
                                    <h:outputLabel value="Prénom : "/>
                                    <h:inputText id="out2" value="#{connectClient.clientTrouve.prenom}"/>
     
                                    <h:outputLabel value="Adresse :"/>
                                    <h:inputText id="out3" value="#{connectClient.clientTrouve.adresse}"/>
     
                                    <h:outputLabel value="Code postale :"/>
                                    <h:inputText id="out4" value="#{connectClient.clientTrouve.code_postale}"/>
     
                                    <h:outputLabel value="Ville : "/>
                                    <h:inputText id="out5" value="#{connectClient.clientTrouve.ville}"/>
     
                                    <h:outputLabel value="Telephone : "/>
                                    <h:inputText id="out6" value="#{connectClient.clientTrouve.telephone}"/>
     
                                    <h:outputLabel value="Mobile : "/>
                                    <h:inputText id="out7" value="#{connectClient.clientTrouve.mobile}"/>
     
                                    <h:outputLabel value="Mail : "/>
                                    <h:inputText id="out8" value="#{connectClient.clientTrouve.mail}"/>
     
                                    <h:outputLabel value="Identifiant : "/>
                                    <h:outputText id="out9" value="#{connectClient.clientTrouve.identifiant}"/>
     
                                    <h:outputLabel value="Mot de passe : "/>
                                    <h:inputText id="out10" value="#{connectClient.clientTrouve.mdp}"/>
     
                                </h:panelGrid>
                            <pou:commandButton id="majClientButton" value="Mise à jour" actionListener="#{modifierInformationClient.test}"/>
                        </pou:panel>
                    </h:form>
                </ui:define>
     
            </ui:composition>
        </h:body>
    </html>
    C'est à ce moment là que j'ai du mal à comprendre comment se passe la persistance de l'objet. Sur la dernière page, j'arrive à faire apparaître le nom du bon client qui s'est identifié, mais si par exemple, dans la page de modification des information du client je veux récupérer les données présentent cela ne fonctionne pas, je m'explique :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
    package DTO;
     
    import DAO.ConnecBDD;
    import java.io.Serializable;
    import java.sql.Connection;
     
    /**
     *
     * @author FixeFred
     */
    public class modifierInformationClient implements Serializable {
     
        //Connexion BDD
        protected static final Connection bdd = ConnecBDD.getInstance();
     
        private connectClient client;
     
        public modifierInformationClient() {
     
        }
     
        public void test(){
            System.out.println("Nom client : "+client.getClientTrouve().getNom());
        }
     
    }
    Un commandButton fait appel à la fonction test(), je voulais simplement savoir si je récupérais les données affichées, mais rien, j'ai une exception "JavaNullException....." qui apparaît.

    Si quelqu'un arrive à m'expliquer comment gérer la session de l'utilisateur ou voit une grosse erreur dans mon code, je suis preneur.

    D'avance merci
    Fred

  2. #2
    Membre éprouvé
    Avatar de Cafeinoman
    Homme Profil pro
    Couteau suisse d'une PME
    Inscrit en
    Octobre 2012
    Messages
    628
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Couteau suisse d'une PME

    Informations forums :
    Inscription : Octobre 2012
    Messages : 628
    Points : 1 256
    Points
    1 256
    Par défaut
    Quand j'ai commencé à utiliser JSF, j'ai aussi buté sur la gestion des utilisateurs. Donc j'ai tapé "jsf gestion utilisateurs" dans la petite boîte de recherche de développez, et le premier résultat c'était ça. Une bonne implémentation je trouve...

  3. #3
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    Si je peux me permettre, il serait préférable d'utiliser une authentification par le conteneur (prévue par JEE) que de développer sa propre sauce...

    Je te suggère donc de regarder du côté des REALM, JAAS etc...
    Très simple à mettre en place dans la plupart des cas, mais dépendant du serveur... Pour un serveur JBoss7 par exemple, ça ce paramètre dans le fichier standalone.xml ou domain.xml en fonction de l'option de démarrage choisie.
    Dans ton application, il suffira de faire le lien dans le web.xml, ça ressemblera à ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    ...
     
        <security-constraint>
            <web-resource-collection>
                <web-resource-name>Mon application</web-resource-name>
                <url-pattern>/views/*</url-pattern>
            </web-resource-collection>
            <auth-constraint>
                <role-name>ADMIN</role-name>
                <role-name>USER</role-name>
            </auth-constraint>
        </security-constraint>
     
        <login-config>
            <auth-method>FORM</auth-method>
            <realm-name>Scout</realm-name>
            <form-login-config>
                <form-login-page>/login.xhtml</form-login-page>
                <form-error-page>/login-error.xhtml</form-error-page>
            </form-login-config>
        </login-config>
     
        <security-role>
            <role-name>ADMIN</role-name>
        </security-role>
        <security-role>
            <role-name>USER</role-name>
        </security-role>
     
    ...
    et de rajouter un fichier jboss-web.xml dans le répertoire /WEB-INF/ pour faire le lien avec le nom du domaine de sécurité
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <?xml version="1.0" encoding="UTF-8"?>
    <jboss-web>
       <security-domain>mon-nom-domaine</security-domain>
    </jboss-web>
    Si tu as besoin de précisions pour un serveur particulier, précise sur quoi tu comptes faire tourner ton application, on pourra certainement t'aider...

  4. #4
    Membre du Club
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Janvier 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 116
    Points : 63
    Points
    63
    Par défaut
    Bonjour à tous,
    Merci pour vos réponses, une bonne base pour reprendre mes erreurs.

    Cette application est destinée à une petite entreprise, elle ne sera pas hébergée sur un serveur particulier, libre choix pour cette phase du projet, je suis ouvert à vos propositions.

    A ce jour sachez que j’exécute l'application sur un serveur Tomcat, j'ai eu des échos comme quoi JBoss était très compliqué à mettre en place.

    Merci

  5. #5
    Membre du Club
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Janvier 2012
    Messages
    116
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 116
    Points : 63
    Points
    63
    Par défaut
    Chose aussi qui me pose problème est la gestion de l'architecture de mon application sur une base MVC :
    - Vue : vue.xhtml
    - Modèle : objet.java , classe serializable
    - Controller : Associé à une vue, vueController.java, classe serializable faisant appel aux objets ?

    Sommes nous d'accord ?

    Merci

  6. #6
    Membre éprouvé
    Avatar de Cafeinoman
    Homme Profil pro
    Couteau suisse d'une PME
    Inscrit en
    Octobre 2012
    Messages
    628
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Couteau suisse d'une PME

    Informations forums :
    Inscription : Octobre 2012
    Messages : 628
    Points : 1 256
    Points
    1 256
    Par défaut
    Globalement oui. Pour ce qui est de l'architecture, je te conseil le tuto de Serge Tahé que tu trouvera ici, qui est très bien quand on commence avec jsf.

    Pour l'authentification, OButterlin à raison, ettu trouveras un tuto qui devrait t'aider ici.

    N'hésite pas à redemander si besoin, et n'oublie pas de passer en résolu si c'est bon.

    Bon courage.

  7. #7
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Points : 9 529
    Points
    9 529
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Fred30 Voir le message
    ...
    A ce jour sachez que j’exécute l'application sur un serveur Tomcat, j'ai eu des échos comme quoi JBoss était très compliqué à mettre en place.
    ...
    Tomcat est un bon petit serveur, si tu ne veux pas utiliser les EJB, c'est un bon choix, sinon, évidemment, il vaut mieux utiliser un serveur complet comme JBoss ou Glassfish (je n'ai pas d'actions dans ces serveurs )...

    Pour ce qui est de la complexité de mettre en oeuvre un serveur JBoss, c'est un gros foutage de gueule si tu veux mon avis, je l'utilise depuis des années et c'est très simple...
    Il est vrai que la version 4.2.3 était ultra simple alors que la version 7 a vu de gros changements mais elle permet des choses que l'ancienne version ne savait pas gérer correctement (comme les dépendances)

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. gestion utilisateur avec J2EE
    Par frangio dans le forum Java EE
    Réponses: 0
    Dernier message: 16/03/2012, 12h10
  2. Replica et gestion utilisateurs
    Par odelayen dans le forum Access
    Réponses: 4
    Dernier message: 09/06/2006, 14h53
  3. [Securite J2EE] Gestion login
    Par jmartell dans le forum Sécurité
    Réponses: 19
    Dernier message: 01/02/2006, 22h23
  4. [formulaire web] gestion de la saisie
    Par Leishmaniose dans le forum Web
    Réponses: 7
    Dernier message: 18/01/2006, 14h33
  5. Gestion utilisateurs avec droits
    Par dr_look dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 27/04/2005, 17h03

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