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

PHP & Base de données Discussion :

Problèlme récupération de données dans sqlserver [ODBC]


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 196
    Points : 53
    Points
    53
    Par défaut Problèlme récupération de données dans sqlserver
    Bonjour,
    j'ai un problème qui m'empêche d'avancer.

    J'ai crée une source de donnée odbc pour sql server.
    J'ai crée ma base de données

    Lorsque je me connecte la connexion se fait apparemment vu que lorsque je fais le test

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <?php 
    session_start();
    $connex = odbc_connect("geststockmazars","","");
    	// TEST DE CONNEXION A LA TABLE (enlever les  /* */)
     
    	IF(!$connex)
    		echo "PROBLEME à la connexion<br />";
    	else
    		echo "Connexion OK"; ?>
    j'ai le message connexion ok qui s'affiche donc c'est que la connexion se fait bien.

    Maintenant quand j'essaie de me connecter je passe tjs dans la boucle qui me met que mon mot de passe est mauvais. :

    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
    if(isset($_POST) && !empty($_POST['login']) && !empty($_POST['pass']))
    {
    	extract($_POST);
    	$pass=sha1($pass); // on crypte le mot de passe tapé en sha1
    	$con = odbc_connect("geststockmazars","",""); // on se connecte à la base de données
    	$sql = " SELECT id,statut FROM users WHERE login='$login' and pass='$pass'";
    	// on effectue la requête sql
    		$req = odbc_do($con, $sql);
    	// on teste le nombre de résultat
    		if(odbc_num_rows($req)>0)
    		{	// s'il est supérieur à 0 c'est que l'utilisateur existe
    			$data= odbc_fetch_array($req);
    			// on créé un tableau de session où on stocke les différentes informations
    			$_SESSION['Auth'] = array(
    			'login' => $login,
    			'pass' => $pass,
    			'statut' => $data['statut']);
     
    //on teste si il est admin ou non et en fonction de cela on le redirige					
    			if($_SESSION['Auth']['statut'] == 'admin')
    			{
    				header('Location:pageprivee.php');	
    			}
    			else
    			{
    				header('Location:pagepublique.php');
    			}
    		}
    		else
    		{	// si pas de résultat c'est que les identifiants sont incorrectes
    			header('location:erreurlog.php');
    		}
    }

    mon fichier auth.php si vosu le souhaitez :

    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
    <?php
     
     
    	Class Auth{
    		static function isLogged()
    		{
    			if(isset($_SESSION['Auth']) && isset($_SESSION['Auth']['login']) && isset($_SESSION['Auth']['pass']) )
    			{	
    				extract($_SESSION['Auth']);
    					$con = odbc_connect("geststockmazars","","");
    				$sql = " SELECT id from users where login='$login' and pass='$pass'";
    				$req = odbc_do($con, $sql);
     
    				if(odbc_num_rows($req)>0)
    				{
    					return true;
    				}
    				else
    				{
    					return false;
    				}
    	        }
    			else
    			{
    				return false;
    			}
    		}
     
    		static function isAdmin()
    			{
    				if(isset($_SESSION['Auth']) && isset($_SESSION['Auth']['login']) && isset($_SESSION['Auth']['pass']) )
    				{
    					extract($_SESSION['Auth']);
    					$con = odbc_connect("geststockmazars","","");
    					$sql = " SELECT statut from users where login='$login' and pass='$pass'";
    					$req = odbc_do($con, $sql);
     
    					if($req='admin')
    					{
    						return true;
    					}
    					else
    					{
    						return false;
    					}
    				}
    				else
    				{
    					return false;
    				}
    			}
     
    	}
     
    ?>
    BIen sur ma table users existe dans sql server et les champs spécifiés dan sla requête aussi.
    Si vosu avez des questions n'hésitez pas.

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    la boucle qui me met que mon mot de passe est mauvais
    de quelle boucle s'agit- il ?

    Sinon as-tu fais le debugage minimum ? afficher tes variables, afficher la requête, contrôler la requête etc. ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 196
    Points : 53
    Points
    53
    Par défaut
    Pardon je me suis trompé quand j'ai posté une partie du code.
    Pour la deuxième c'est ça 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
    if(isset($_POST) && !empty($_POST['login']) && !empty($_POST['pass']))
    {
    	extract($_POST);
    	$pass=sha1($pass); // on crypte le mot de passe tapé en sha1
    	$con = odbc_connect("geststockmazars","",""); // on se connecte à la base de données
    	$sql = " SELECT id,statut FROM users WHERE login='$login' and pass='$pass'";
    	// on effectue la requête sql
    		$req = odbc_do($con, $sql);
    	// on teste le nombre de résultat
    		if(odbc_num_rows($req)>0)
    		{	// s'il est supérieur à 0 c'est que l'utilisateur existe
    			$data= odbc_fetch_array($req);
    			// on créé un tableau de session où on stocke les différentes informations
    			$_SESSION['Auth'] = array(
    			'login' => $login,
    			'pass' => $pass,
    			'statut' => $data['statut']);
     
    //on teste si il est admin ou non et en fonction de cela on le redirige					
    			if($_SESSION['Auth']['statut'] == 'admin')
    			{
    				header('Location:pageprivee.php');	
    			}
    			else
    			{
    				header('Location:pagepublique.php');
    			}
    		}
    		else
    		{	// si pas de résultat c'est que les identifiants sont incorrectes
    			header('location:erreurlog.php');
    		}
    }
    Et donc là je parle de quand je suis redirigé vers la page erreurlog.php
    Euh non je n'ai aps fait les tests dont tu me parles.
    Tu peux m'en dire plus ?

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $sql = " SELECT id,statut FROM users WHERE login='$login' and pass='$pass'";
    echo $sql .'<br/>';
    	// on effectue la requête sql
    		$req = odbc_do($con, $sql);
    var_dump($req);
    	// on teste le nombre de résultat
    echo odbc_num_rows($req);
    		if(odbc_num_rows($req)>0)

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 196
    Points : 53
    Points
    53
    Par défaut
    Voilà le résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Connexion OK SELECT id,statut FROM users WHERE login='didier' and pass='65d0f74bf4e86747987eb7d8353e2423639501dc'
     
    resource(5, odbc result)
     
    0
    Donc ça veut dire qu'il ne trouve pas de résultat pour ce que j'ai tapé comme identifiant dans la base de données c'est ça ? Pourtant ce login et ce pass existe dans ma base de données...

    Le ressource je ne comprends pas bien par contre.

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    C'est bien ça : il n'y a pas de ligne qui ait ce login et ce mot de passe.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2010
    Messages
    196
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2010
    Messages : 196
    Points : 53
    Points
    53
    Par défaut
    Bah pourtant regarde il y est bien dans la bdd...

    http://img706.imageshack.us/i/screenshot034u.jpg/

    edit : je viens de tester en mettant un mot de passe et login non crypté (comme dans la photo) et j'ai enlevé le sha1 que j'utilisais et apparemment je me connectes donc ça viendrait de mon sha1.
    N'existe t-il pas un autre moyen de crypter en sha1 de manière fonctionnelle ?

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    dans ta base le login est "dider" et pas "didier"

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

Discussions similaires

  1. Problème de récupérations de données dans une table mysql
    Par Helpine dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/03/2006, 19h07
  2. [VB]Récupération de données dans Excel
    Par jeanangel dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/01/2006, 23h30
  3. Réponses: 16
    Dernier message: 10/11/2005, 21h10
  4. Réponses: 6
    Dernier message: 23/10/2005, 12h24
  5. récupération de données dans un TDBControlGrid
    Par dableuf dans le forum Bases de données
    Réponses: 3
    Dernier message: 22/11/2004, 14h25

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