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

VB.NET Discussion :

Problème connexion base Access et vb.net


Sujet :

VB.NET

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    56
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2012
    Messages : 56
    Points : 60
    Points
    60
    Par défaut Problème connexion base Access et vb.net
    Bonjour,

    Je suis en train de créer une application avec vb.net 2010 et access 2007. J'ai débuter à créer un écran d'authentification qui est composé de deux champs texte l'un pour login et l'autre pour mot de passe. Ma base de donnée créer par access 2007 contient une table user qui contient les champs suivant: login,password,nom,prénom,statut(0:admin,1:simple user), adresse.

    Ci-dessous le code :

    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
    Imports System
    Imports System.Data
    Imports System.Data.OleDb
    Imports Microsoft.VisualBasic
     
    Public Class authentificationForm
     
        Private Sub connexionBouton_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles connexionBouton.Click
            Dim lg As String = Me.loginTextbox.Text()
     
            '  Déclaration Objet Connexion
     
            Dim MyConnexion As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data source=C:\Users\NHaouel\Desktop\ecureuilServices\P13PRESSING\P13PRESSING_DB.accdb")
     
            ' Déclaration Objet Commande
     
            Dim MyCommand As OleDbCommand = MyConnexion.CreateCommand()
            ' MyCommand.CommandText = "SELECT [login,password] FROM [User] WHERE login = ' " + loginTextbox.Text + " ' and password = ' " + passwordTextBox.Text + " ' "
            MyCommand.CommandText = "SELECT login FROM [User] WHERE login = ' " & lg & " ' "
     
            MyConnexion.Open()
     
                Dim MyReader As OleDbDataReader = MyCommand.ExecuteReader()
            If MyReader.Read Then
                adminAccueil.Show()
                Me.Hide()
            Else
                MsgBox("Erreur! Utilisateur non reconnu!")
            End If
     
            MyReader.Close()
     
            MyConnexion.Close()
     
        End Sub
    End Class
    Après l'execution: le message d'erreur s'affiche direct "Erreur! Utilisateur non reconnu!" meme si le login entré est dans la base de donnée.


    Merci

  2. #2
    Membre habitué
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Mai 2012
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Industrie

    Informations forums :
    Inscription : Mai 2012
    Messages : 175
    Points : 151
    Points
    151
    Par défaut
    bonjour

    je vois pas d'erreur sauf personnelement je préfère utiliser "Like"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE login Like ' " & lg & " ' "
    et de préférence utiliser des requetes avec des parametres

    A+

  3. #3
    Membre régulier
    Homme Profil pro
    Technicien Help Desk
    Inscrit en
    Novembre 2006
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien Help Desk
    Secteur : Bâtiment Travaux Publics

    Informations forums :
    Inscription : Novembre 2006
    Messages : 129
    Points : 106
    Points
    106
    Par défaut
    Citation Envoyé par foufou.mr Voir le message
    Après l'execution: le message d'erreur s'affiche direct "Erreur! Utilisateur non reconnu!" meme si le login entré est dans la base de donnée.
    C'est donc ton IF qui déconne.

    J'utilise While :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    While Datareader.Read()
          log = true
    End While
    Et merci d'utiliser les balises CODE pour que ce soit plus clair au niveau de la lecture.

    ++

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 722
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 722
    Points : 5 100
    Points
    5 100
    Par défaut
    Bonjour,

    @prologic
    Citation Envoyé par prologic Voir le message
    J'utilise While :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    While Datareader.Read()
          log = true
    End While
    Je ne vois pas en quoi le While résoudrait le problème.
    Si le test dans le if renvoie faux, le while renverra faux aussi.
    L'instruction While est prévue pour effectuer une boucle, la détourner de son but afin d'effectuer un test est une mauvaise idée.
    ________________________

    Ici, on peut simplement tester si MyReader contient une ou plusieurs lignes avec l'instruction HasRows.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
        Using MyReader As OleDbDataReader = MyCommand.ExecuteReader()
            If MyReader.HasRows Then
                adminAccueil.Show()
                Me.Hide()
            Else
                MsgBox("Erreur! Utilisateur non reconnu!")
            End If
            'MyReader.Close() ' devenu inutile, le End Using effectuant la fermeture
        End Using
    Remarque : comme le souligne abd75web il est préférable d'utiliser les requêtes paramétrées. Voir Tuto ou Faq.

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

Discussions similaires

  1. Problème connexion base Access, Windows 7 64bits
    Par crazyangelbones dans le forum JDBC
    Réponses: 1
    Dernier message: 05/02/2010, 01h45
  2. Problème connexion base Access
    Par melleb dans le forum MFC
    Réponses: 6
    Dernier message: 15/10/2009, 11h13
  3. Problème Connexion base Access
    Par Booyakha dans le forum ASP.NET
    Réponses: 4
    Dernier message: 25/08/2009, 13h00
  4. problème de connexion base access
    Par garthalgar dans le forum ASP
    Réponses: 3
    Dernier message: 23/07/2007, 15h41
  5. Problème de connexion base Access
    Par Ricardo_Tubbs dans le forum ASP
    Réponses: 3
    Dernier message: 21/02/2006, 16h06

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