Partage
  • Partager sur Facebook
  • Partager sur Twitter

soucis de connexion en php

Sujet résolu
    11 avril 2024 à 13:37:47

    Bonjour j'ai écris un code de connexion a un espace membre mais le problème est que j'ai 2 types d'utilisateurs dans mon site et chaque user a sa table j'ai donc écris une condition if dans mon code mais le problème est que elle ne teste pas la première et teste direct la deuxième si fausse passe direct au message d'erreur voila mon code :
    <?php
        require('config.php');
        session_start();
        if (isset($_REQUEST['email'],$_REQUEST['passcon'])) {
            $Email = stripslashes($_REQUEST['email']);
            $Email = mysqli_real_escape_string($conn, $Email);
    
            $passcon = stripslashes($_REQUEST['passcon']);
            $passcon = mysqli_real_escape_string($conn, $passcon);
    
            $sql = "SELECT * FROM user WHERE E_mailuser='$Email' and mdp_user='".hash('sha256', $passcon)."'";
            $sql1 = "SELECT * FROM entreprise WHERE E_mailent='$Email' and mdp_ent='".hash('sha256',$passcon)."'";
            $result1 = mysqli_query($conn, $sql);
            $result = mysqli_query($conn, $sql1);
            
            if (mysqli_num_rows($result) == 1) {
                $entreprise = mysqli_fetch_assoc($result);
                $_SESSION['ident'] = $entreprise['id_ent'];
                $_SESSION['noment'] = $entreprise['nom_ent'];
                $_SESSION['emailent'] = $entreprise['E_mailent'];
                $_SESSION['categorie_ent'] = $entreprise['categorie_ent'];
                $_SESSION['mdpent'] = $entreprise['mdp_ent'];
                $_SESSION['logo'] = $entreprise['logo'];
                header('location: compte_ent.php');
            }
            elseif (mysqli_num_rows($result1) == 1) {
                $user = mysqli_fetch_assoc($result1);
                $_SESSION['iduser'] = $user['id_user'];
                $_SESSION['nomuser'] = $user['nom_user'];
                $_SESSION['prenomuser'] = $user['prenom_user'];
                $_SESSION['emailuser'] = $user['E_mailuser'];
                $_SESSION['tel'] = $user['tel_user'];
                $_SESSION['sexe'] = $user['sexe'];
                $_SESSION['mdpuser'] = $user['mdp_user'];
                $_SESSION['ppuser'] = $user['photouser'];
                header('location: compteuser.php');
            }else{
                $message = "Adresse mail ou mot de passe incorrect";
            }          
        }
        ?>
    pourriez vous m'aider s'il vous plait et merci d'avance.

    -
    Edité par BeginMurky 11 avril 2024 à 14:07:18

    • Partager sur Facebook
    • Partager sur Twitter
      11 avril 2024 à 13:50:50

      Bonjour, Merci d'indiquer un titre en rapport avec votre problématique.

      Le message qui suit est une réponse automatique activée par un membre de l'équipe de modération. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Mauvais titre

      Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

      Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

      De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

      Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

      Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

      (titre originel : probleme en php)

      Liens conseillés

      • Partager sur Facebook
      • Partager sur Twitter
        11 avril 2024 à 14:29:14

        BeginMurky a écrit:

        Bonjour j'ai écris un code de connexion a un espace membre mais le problème est que j'ai 2 types d'utilisateurs dans mon site et chaque user a sa table j'ai donc écris une condition if dans mon code mais le problème est que elle ne teste pas la première et teste direct la deuxième si fausse passe direct au message d'erreur voila mon code :

        <?php
            require('config.php');
            session_start();
            if (isset($_REQUEST['email'],$_REQUEST['passcon'])) {
                $Email = stripslashes($_REQUEST['email']);
                $Email = mysqli_real_escape_string($conn, $Email);
        
                $passcon = stripslashes($_REQUEST['passcon']);
                $passcon = mysqli_real_escape_string($conn, $passcon);
        
                $sql = "SELECT * FROM user WHERE E_mailuser='$Email' and mdp_user='".hash('sha256', $passcon)."'";
                $sql1 = "SELECT * FROM entreprise WHERE E_mailent='$Email' and mdp_ent='".hash('sha256',$passcon)."'";
                $result1 = mysqli_query($conn, $sql);
                $result = mysqli_query($conn, $sql1);
                
                if (mysqli_num_rows($result) == 1) {
                    $entreprise = mysqli_fetch_assoc($result);
                    $_SESSION['ident'] = $entreprise['id_ent'];
                    $_SESSION['noment'] = $entreprise['nom_ent'];
                    $_SESSION['emailent'] = $entreprise['E_mailent'];
                    $_SESSION['categorie_ent'] = $entreprise['categorie_ent'];
                    $_SESSION['mdpent'] = $entreprise['mdp_ent'];
                    $_SESSION['logo'] = $entreprise['logo'];
                    header('location: compte_ent.php');
                }
                elseif (mysqli_num_rows($result1) == 1) {
                    $user = mysqli_fetch_assoc($result1);
                    $_SESSION['iduser'] = $user['id_user'];
                    $_SESSION['nomuser'] = $user['nom_user'];
                    $_SESSION['prenomuser'] = $user['prenom_user'];
                    $_SESSION['emailuser'] = $user['E_mailuser'];
                    $_SESSION['tel'] = $user['tel_user'];
                    $_SESSION['sexe'] = $user['sexe'];
                    $_SESSION['mdpuser'] = $user['mdp_user'];
                    $_SESSION['ppuser'] = $user['photouser'];
                    header('location: compteuser.php');
                }else{
                    $message = "Adresse mail ou mot de passe incorrect";
                }          
            }
            ?>

        pourriez vous m'aider s'il vous plait et merci d'avance.

        -
        Edité par BeginMurky il y a 21 minutes

        ok finalement le problème n'est pas ici mais ailleurs dans mon code il est résolu merci ce code je le laisse donc a ce qui pourrait en avoir besoin

        -
        Edité par BeginMurky 11 avril 2024 à 14:33:01

        • Partager sur Facebook
        • Partager sur Twitter

        soucis de connexion en php

        × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
        • Editeur
        • Markdown