Partage
  • Partager sur Facebook
  • Partager sur Twitter

Enregistrement conditionnel qui passe la condition

Sujet résolu
    19 novembre 2019 à 11:18:05

     Bonjour à tous et à toutes^^,

    J'ai un problème sur la condition de l'ajout en base de donnée je sais pas trop comment m'y prendre, je suis un peu perdu.

    J'ai crée une fonction avec comme paramètre mes post(s) ainsi que mes regex(s) et je voudrais mettre une condition avant l'ajout en base pour vérifier si

    tous est ok on ajoute sinon bah non.

    Merci d'avance pour vos critiques et pour votre aide.

    $regexLastName = ' /^([a-zA-Zéèçà]+)|[-]{1}([a-zA-Zéèçà]+)$/ ';
    $regexFirstName = ' /^([a-zA-Zéèçà]+)|[-]{1}([a-zA-Zéèçà]+)$/ ';
    $regexMail = " /^[[:alnum:]]([-_.]?[[:alnum:]])*@[[:alnum:]]([-.]?[[:alnum:]])*\.([a-z]{2,4})$/ ";
    $regexPhone = " /^(?:(?:\+|00)33|0)\s*[1-9](?:[\s.-]*\d{2}){4}$/ ";
    $regexBirth = " /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]((?|19|20)\d\d)$/ ";
    
    function patternRegex($post, $regex)
    {
      $arrayName = array(
        $_POST['mail'] => 'Veuillez entrez une adresse mail valide', $_POST['lastName'] => 'Veuillez saisir un nom Valide',
        $_POST['firstName'] => 'Veuillez saisir un prénom valide', $_POST['phone'] => 'Veuillez saisir un numéro de téléphone valide',
        $_POST['birthday'] => 'Veuillez saisir une date de naissance valide'
      );
    
      if (!preg_match($regex, $post)) {  
        if ($post == null || $post == '') {
          echo '<p class="text-danger"> Ce champ est obligatoire ! </p>';
        } else {
          echo '<p class="text-danger">' . $arrayName[$post] . '</p>';
        }
      }
    }
    // Mise en place variable pour traiter dans la procédure stockée
    $lastName = $_POST['lastName'];
    $firstName = $_POST['firstName'];
    $birthdate = $_POST['birthday'];
    $phone = $_POST['phone'];
    $mail = $_POST['mail'];
    
    // Format Date 2003-10-16
    
    $datedate = strtotime($birthdate);
    $newDate = date('Y-m-d', $datedate);
    
    if (isset($_POST['validationPatient'])) {
      // Insertion des champs requis dans la base de donnée
      $req = $bdd->prepare('INSERTINTO patients(lastname, firstname, birthdate, phone, mail) VALUES (:lastName ,:firstName,:birthday,:phone,:mail)');
    
      // Exécution de la requéte pour ajout en base de donnée
      $req->execute(array('lastName' => $lastName, 'firstName' => $firstName, 'birthday' => $newDate, 'phone' => $phone, 'mail' => $mail));
    }



    -
    Edité par LuffyBee 20 novembre 2019 à 9:41:27

    • Partager sur Facebook
    • Partager sur Twitter
      19 novembre 2019 à 11:22:39

      Salut,

      tu peux mettre ton code dans les balises code: bouton </> + PHP dans la liste.

      Merci c'est illisible là.

      • Partager sur Facebook
      • Partager sur Twitter
        19 novembre 2019 à 11:24:20

        Bonjour,

        Merci de colorer votre code à l'aide du bouton Code

        Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue. Si vous utilisez l'éditeur de messages en mode Markdown, il faut utiliser les balises <pre class="brush: php;">Votre code ici</pre>.

        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.

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

        (titre originel : Problème d'ajout en base)


        Autres points :

        inutile de créer une regex pour les mails, en php on a filter_var (https://www.php.net/filter_var) qui fait très bien le boulot - d'autant que ta regex est trop restrictive, elle empêche de mettre "+" dans la partie gauche, et les noms de domaines dont la longueur est supérieure à 4 caractères ("paris", "ninja", "audio"…) ne seront pas acceptés non plus.

        Peux-tu également *décrire* le problème ?

        • Partager sur Facebook
        • Partager sur Twitter

        Pas d'aide concernant le code par MP, le forum est là pour ça :)

          19 novembre 2019 à 11:30:19

          Je pense que c'est bon, désoler 1er post^^.

          Oui le problème étant que je veux pouvoir faire une condition juste avant mon ajout et dire que si il y a un problème que j'aurais récupérer de ma fonction de ne pas ajouter en base le formulaire.

          Quand je rentre une mauvaise valeur il me l'ajoute en base quand même du genre 06554422ff.

          Voila j'espère avoir été claire.

          PS: Merci de l'astuce pour la regex mails.

          -
          Edité par LuffyBee 19 novembre 2019 à 11:34:24

          • Partager sur Facebook
          • Partager sur Twitter
            19 novembre 2019 à 12:20:50

            Bonjour,

            Active les erreurs PDO (cf ma signature)

            Cela te donnera une erreur de syntaxe (espace entre INSERT et INTO)

            • Partager sur Facebook
            • Partager sur Twitter
              19 novembre 2019 à 15:19:57

              Pour le titre, c'est toujours incorrect. Nul besoin de préciser le langage, on est déjà sur le forum PHP. Par contre, ce qui était attendu c'est une description concise du souci, comme "Enregistrement conditionnel qui passe la condition", ce genre de chose.

              Merci pour les précisions et la coloration du code, c'est très clair :)

              • Partager sur Facebook
              • Partager sur Twitter

              Pas d'aide concernant le code par MP, le forum est là pour ça :)

                19 novembre 2019 à 16:27:05

                Bonjour,

                Tu a créé une fonction "patternRegex" mais, pour ce que j'en vois, tu ne l'appelle jamais nulle part donc tu ne l'utilise pas. Donc en effet, peu importe ce que tu envoie dans le formulaire, ça insère en bdd :) il faudrait un appel du genre:

                if ( patternRegex( $arg1, $arg2) {
                  // insert BDD
                }else{
                  // msg d'erreur
                }

                et il faut que ta fonction renvoie une valeur, ici un bool (true / false)

                • Partager sur Facebook
                • Partager sur Twitter
                  20 novembre 2019 à 9:40:02

                  Hello,

                  Désoler pour le titre je modifie sa de suite (pas très bon pour les titres^^)

                  Merci du coup pifou25 sa fonctionne avec le return booléen dans ma fonction, c'était ce qui me manquait :) .

                  Voila ce que j'ai mis du coup : 

                  function patternRegex($post, $regex) {
                  
                    $arrayName = array(
                      $_POST['mail'] => 'Veuillez entrez une adresse mail valide', $_POST['lastName'] => 'Veuillez saisir un nom Valide',
                      $_POST['firstName'] => 'Veuillez saisir un prénom valide', $_POST['phone'] => 'Veuillez saisir un numéro de téléphone valide',
                      $_POST['birthday'] => 'Veuillez saisir une date de naissance valide'
                    );
                  
                    if (!preg_match($regex, $post)) {
                      if ($post == null || $post == '') {
                        echo '<p class="text-danger"> Ce champ est obligatoire ! </p>';
                      } else {
                        echo '<p class="text-danger">' . $arrayName[$post] . '</p>';
                      }
                      $bool = false;
                      return $bool;
                    }
                    else {
                      $bool = true;
                      return $bool;
                    }
                  }
                  



                  -
                  Edité par LuffyBee 20 novembre 2019 à 9:42:37

                  • Partager sur Facebook
                  • Partager sur Twitter

                  Enregistrement conditionnel qui passe la condition

                  × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
                  × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
                  • Editeur
                  • Markdown