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

JDBC Java Discussion :

Bonjour besoin d'aide je n'arrive pas à me connecter avec le login que j'ai crée.


Sujet :

JDBC Java

  1. #1
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Bonjour besoin d'aide je n'arrive pas à me connecter avec le login que j'ai crée.
    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Erreur de syntaxe près de ''username ='tantie'and password='kadiatou'' à la ligne 1
    Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
    at base_de_donnees.Login.jButton1ActionPerformed(Login.java:124)

  2. #2
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2017
    Messages
    95
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2017
    Messages : 95
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par DEMBELE10 Voir le message
    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Erreur de syntaxe près de ''username ='tantie'and password='kadiatou'' à la ligne 1
    Exception in thread "AWT-EventQueue-0" java.lang.NullPointerException
    at base_de_donnees.Login.jButton1ActionPerformed(Login.java:124)

    Bonjour,

    Au doigt mouillé, je dirais qu'il manque un quote à la fin de ta requête.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    username ='tantie'and password='kadiatou'

  3. #3
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Passer par un PreparedStatement évite ce genre de souci de quote, et prévient contre les injections SQL...
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  4. #4
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Points : 3
    Points
    3
    Par défaut
    Citation Envoyé par Iloyd Voir le message
    Bonjour,

    Au doigt mouillé, je dirais qu'il manque un quote à la fin de ta requête.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    username ='tantie'and password='kadiatou'

  5. #5
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Voici la requete:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs = db.querySelectAll("utilisateur", "'username ='" + txt_username.getText()+ "'and password='" + txt_password.getText()+ "'");

  6. #6
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Bah, c'est quoi ce db ? Une variable qui pointe sur un objet de classe à toi ? Qui manifestement n'utilise pas de PreparedStatement (ou alors il y a un parser SQL derrière...). Avec un tel code en plus si on tape une quote dans le champ de saisie, ça plante. Et si quelqu'un introduit une requête SQL (avec quelques quotes bien placées...) dans le champ de saisie, il va pouvoir faire des choses qu'on ne veut pas qu'il fasse...
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  7. #7
    Membre régulier
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2017
    Messages
    95
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2017
    Messages : 95
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par DEMBELE10 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    rs = db.querySelectAll("utilisateur", "'username ='" + txt_username.getText()+ "'and password='" + txt_password.getText()+ "'");
    Passer par un .querySelectAll pour une requête comme ça me semble inutile. Tu peux reprendre la forme d'une requête SQL préparée ou bien par concaténation (comme tu l'as fait (à peu près) ci - dessus).


    requête préparée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    String sql = "select nomUtilisateur, mdpUtilisateur from dbo.p_utilisateur where nomUtilisateur=? and mdpUtilisateur=?"; //requête préparée pour le login
            try{
                cnx = DBConnexion.ConnectDB(); //connexion bdd
                prepared = cnx.prepareStatement(sql); //instruction paramétrée avec une reuqête SQL déjà compilée
                prepared.setString(1,unUtilisateur.getLogin()); //définit le paramètre selon le string donné 
                prepared.setString(2,unUtilisateur.getMdp()); //définit le paramètre selon le string donné 
     
                resultat = prepared.executeQuery(); //exécute la requête
     
                .....
            }catch(SQLException e){e.printStackTrace();}
    requête par concaténation :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    String sql = "select nomUtilisateur, mdpUtilisateur from dbo.p_utilisateur where nomUtilisateur='"+txtLogin.getText()+"' and mdpUtilisateur='"+txtMdp.getText()+"'"; //requête préparée pour le login
            try{
                cnx = DBConnexion.ConnectDB(); //connexion bdd
                prepared = cnx.prepareStatement(sql); //instruction paramétrée avec une reuqête SQL déjà compilée
     
                resultat = prepared.executeQuery(); //exécute la requête
     
                .......
            }catch(SQLException e){e.printStackTrace();}

  8. #8
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Points : 3
    Points
    3
    Par défaut Bonjour ! bon je suis débutant en java peut être que c'est à cause ça merci d'avance
    Je sais comment faire avec prepareStatement je voulais aussi apprendre à le faire autrement c'est pourquoi j'ai codé de la sorte , quand j’exécute on me parle d'erreur de syntaxe près de: Erreur de syntaxe près de ''username =''and password=''' à la ligne 1

  9. #9
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    1. Si tu sais le faire avec des PreparedStatement, ça suffit. Il y a d'autres moyens de le faire, mais pas les Statements, soit par concaténation, parce que comme je l'ai déjà dit,
      1. gérer les quotes est une plaie (et ça peut être spécifique au SGBD en plus)
      2. que ça permet les injections SQL
    2. Quand tu as une erreur, le mieux est de préciser si c'est
      • une erreur de compilation et d'indiquer le message exacte, et le code concerné à minima (la ligne en particulier)
      • ou d'exécution, et d'indiquer le message, la stacktrace, et le code concerné à minima (la ligne en particulier), et l'environnement d'exécution (variables, paramètres, etc).

      Sans quoi on n'est réduit à faire des suppositions et des interprétations. ''username =''and password=''' en Java comme en SQL, est incorrecte syntaxiquement parlant.
      En SQL, l'expression serait select id from table where username = 'name' and password = 'pass'. Pour produire cette chaîne à partir de valeurs qui seraient saisies dans des champs, par concaténation, il faudrait faire :
      Code JAVA : Sélectionner tout - Visualiser dans une fenêtre à part
      String sql = "select id from table where username = '" + escape(namefield.getText()) + "' and password = '" + escape(password.getText()) +"'"
      ou escape serait une méthode que tu programmes toi-même (on pourrait empêcher de saisir des quotes dans les champs aussi).
      Note bien déjà la difficulté de distinguer les ' et les " dans ce genre d'expression et qui peut conduire à des erreurs. En tout, " n'est pas '', ni "' ni '" n'est ''', etc. Ensuite il faut écrire le code de la méthode escape pour que les quotes saisies dans le champ n'interfèrent pas avec la syntaxe SQL, n'empêchent pas le SQL de fonctionner conformément à ce qu'on veut.
      Avec les PreparedStatement, pas de question à se poser, pas de fonction escape() à écrire, ça marche tout seul et sans risque. Maintenant, le source du PreparedStatement doit être disponible et en mode debug tu pourras découvrir comment c'est fait une interne si ça t'intéresse vraiment.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  10. #10
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2020
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Mali

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2020
    Messages : 5
    Points : 3
    Points
    3
    Par défaut D'accord!
    Merci beaucoup pour votre aide ,j'essaye ça et je vous ferai un retour !

Discussions similaires

  1. Je n'arrive pas à me connecter avec Sql*Plus
    Par Manequin dans le forum Sql*Plus
    Réponses: 2
    Dernier message: 26/06/2018, 19h57
  2. [WS 2008 R2] Citrix n'arrive pas à se connecter à une autre classe que user de l'AD
    Par Christophe P. dans le forum Windows Serveur
    Réponses: 1
    Dernier message: 08/09/2017, 14h20
  3. besoin d'aide sur une requete (pas forcement difficile)
    Par igorzup dans le forum Développement
    Réponses: 2
    Dernier message: 30/10/2007, 10h27

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