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

Langage PHP Discussion :

Les formulaires, migration PHP5.5 --> PHP7


Sujet :

Langage PHP

  1. #1
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut Les formulaires, migration PHP5.5 --> PHP7
    Bonjour à tous
    je viens de passer de PHP5.5 à PHP7.0, mes formulaires ne marche plus, le script se bloque.
    j'ai déjà essayé plein de modifif pour cerner le problème, j'ai cherché une doc me donnant les différences entre php5.5 et php7.0, mais la plupart du temps, cela dépasse mon niveau.

    voici se qui fonctionné sous php5 et qui ne fonctionne plus.
    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
    if (isset($_POST['nom']) AND isset($_POST['prenom']) AND isset($_POST['num']) AND isset($_POST['rue']) AND isset($_POST['code']) AND isset($_POST['localite']) AND isset($_POST['gsm']) AND isset($_POST['tel']) AND isset($_POST['pwd']) AND isset($_POST['affil']) AND isset($_POST['adresse_mail']) AND isset($_POST['val']))
    	{
    		if ($_POST['nom'] != NULL AND ($_POST['prenom'] != NULL))	
    		{			
    		$nom = htmlspecialchars($_POST['nom'], ENT_QUOTES); 
    		$prenom = htmlspecialchars($_POST['prenom'], ENT_QUOTES);
    		$num = htmlspecialchars($_POST['num'], ENT_QUOTES);
    		$rue = htmlspecialchars($_POST['rue'], ENT_QUOTES);	
    		$code = htmlspecialchars($_POST['code'], ENT_QUOTES);
    		$localite = htmlspecialchars($_POST['localite'], ENT_QUOTES);
    		$gsm = htmlspecialchars($_POST['gsm'], ENT_QUOTES);
    		$tel = htmlspecialchars($_POST['tel'], ENT_QUOTES);
    		$pwd = htmlspecialchars($_POST['pwd'], ENT_QUOTES);
    		$pwd_sha1 = sha1($pwd); 
    		$affil = htmlspecialchars($_POST['affil'], ENT_QUOTES);
    		$val = htmlspecialchars($_POST['val'], ENT_QUOTES);
     
    		if ($_POST['adresse_mail'] != NULL)
    			{
    				if (preg_match("#^[a-z0-9._-]+@[a-z0-9._-]{2,}\.[a-z]{2,4}$#", $_POST['adresse_mail']))//controle du mail
    				{
    					$adresse_mail = htmlspecialchars($_POST['adresse_mail'], ENT_QUOTES);
    pourriez-vous m'aider, merci d'avance

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Là, comme ça, ton script a l'air correct. Bon, ce n'est pas le plus beau code du monde, je ne suis pas sûre que les appels à htmlsepcialchars soient utiles là où ils sont, mais ce code n'a pas l'air de faire appel des fonctionnalités supprimées, ni rien du même genre.

    Cela dit, comme on ne voit ni le formulaire proprement dit, ni la fin du script, et qu'on ne sait pas quel est le problème exact, le message d'erreur ou le comportement, ce n'est pas facile de vérifier En gros, c'est un peu comme si tu nous postais une photo de toi au-dessus de la taille et tu nous disais "je ne peux pas marcher, pourquoi ?"
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    Bon, ce n'est pas le plus beau code du monde
    et oui je débute .......

    je croyais que certaines partie de ce code n'est plus compatible avec PHP7, car il a fonctionné très bien plus d'un ans sous PHP5.il m'est difficile de te mettre un code d'erreur, car dès que j'ajoute cette partie de code, la page ne s'ouvre plus, elle est blanche et aucun message.

    je continue a cherché

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Une page blanche, c'est symptôme d'une erreur non affichée.
    Essaye de changer le niveau d'erreurs en E_ALL : soit par error_​reporting, soit dans la configuration au niveau du php.ini http://php.net/manual/fr/errorfunc.c...rror-reporting
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    Essaye de changer le niveau d'erreurs en E_ALL : soit par error_​reporting
    J'ai essayé tous les exemples proposé dans ton lien et aucun message, une page blanche.

    J'ai quasi le même code pour faire des modifications des données, et il marche impeccable.

    [Édité]
    bon j'avance, mon problème actuel est que cela fonctionne, si tout les champ du formulaire sont complété, si un seul reste vide, ça ne marche plus

    cela pourrait-il venir de ma table (NULL et NO NULL ou autre)

    auriez vous une idée ?

  6. #6
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    je reprendrais le code d'insertion en base de données histoire de repartir sur une nouvelle base. Quelque chose dans ce style :
    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
    $data      = [];
    // tableau des colonnes de la table yves2  
    $db_fields = explode(' ', 'nom prenom num rue code localite gsm tel pwd affil adresse_mail val');
    // tableau des clés du tableau $_POST correspondant au nom de colonne de la table yves2
    // je considère que les noms des contrôles du formulaire sont raccords avec les colonnes de la table yves2
    $post_keys = explode(' ', 'nom prenom num rue code localite gsm tel pwd affil adresse_mail val');
     
    $map_post_db = array_combine($post_keys, $db_fields);
    // tableau des valeurs obligatoires
    $required    = array_fill_keys(explode(' ', 'nom prenom pwd adresse_mail'), true);
     
    // récupération des données du formulaire via $_POST
    foreach ($post_keys as $k) {
        if (isset($_POST[$k])) {
            $data[$map_post_db[$k]] = $_POST[$k];
        }
    }
     
    // vérification de la présence des clés obligatoires
    if (count(array_intersect_key($required, $_POST)) !== count($required)) {
        echo 'Erreur de saise : veuillez remplir toutes les valeurs obligatoires';
        exit;
    }
     
    // validation de l'email
    if (empty(filter_var($data['adresse_mail'], FILTER_VALIDATE_EMAIL))) {
        echo 'Erreur de saise : veuillez fournir un email valide';
        exit;
    }
     
    // génération du SQL limité aux valeurs récupérées
    $sql  = 'INSERT INTO yves2 ('.implode(', ', array_keys($data)).') VALUES ('.implode(', ', array_fill(0, count($data), '?')).')';
    $stmt = $con->prepare($sql);
    $exec = $stmt->execute($data);
     
    if ($exec) {
        // réussite
    } else {
        // échec
    }

  7. #7
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    grand merci rawsrc pour ce code tout prêt.

    je t'avouerais que j'avais du mal avec le miens, mais avec le tien, je suis totalement largué.
    malheureusement, cela ne fonctionne pas, rien n'est écrit dans ma table.
    j'ai corrigé une petite inversion "adresse_mail et affil"

    ceci ne fonctionne pas non plus
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    // tableau des valeurs obligatoires
    $required    = array_fill_keys(explode(' ', 'nom prenom pwd adresse_mail'), true);
    // vérification de la présence des clés obligatoires
    if (count(array_intersect_key($required, $_POST)) !== count($required)) 
    {
    echo 'Erreur de saise : veuillez remplir toutes les valeurs obligatoires';
    exit;
    }
    et malgrès le fait que l'enregistrement ne se fait pas, le message échec ne s'affiche jamais

    ne serait-il pas possible que le soucis vienne de la configuration de ma table ?

  8. #8
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Ben c'est du code sorti du four sans aucun test, n'ayant pas accès à plus, souvent on fait des devinettes et parfois on tombe juste.
    Dans tous les cas, même si le code ne fonctionne pas tel quel, il met souvent sur la bonne piste.

    Il faudrait que tu poses des var_dump() pour vérifier les données reçues.
    Enfin la partie écriture en base, c'est l'approche POO de mysqli, là aussi il manque pas mal d'infos pour voir pourquoi ça ne produit pas le résultat escompté.
    Bref, c'est pas facile ni pour toi, ni pour ceux qui tentent de filer un coup de main et j'ai déjà vu des fils de discussion dépasser les 100 messages autour d'un seul problème le temps de bien cerner l'environnement.

  9. #9
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    N'aie crainte, je comprends bien la difficulté, de régler un problème a distance, en n'ayant pas accès a toutes les infos et je vous remercie grandement de bien vouloir vous intéresser a mon problème.

    j'ai trouvé la source du problème, en lançant les requêtes a partir de phpmyadmin.
    les colonnes de type "int()" doivent absolument recevoir une information, si dans ma requête VALUES( la valeur est ' ' ) ,la requête est refusée.
    les colonnes de type "Vachar" par contre tolère cela sans problème.

    je peux tout mettre en type "vachar", sauf l' ID a cause de l'incrémentation qui ne fonctionne pas en type "vachar"
    mais cela ne serait pas logique, les colonnes destinées a recevoir des nombres doivent être définies comme telle.

    pour résumer :
    si je crée dans mon formulaire un champ ID et que j'adapte le script, quand j'entre le numéro de l'ID manuellement dans le formulaire, cela fonctionne parfaitement.

    [Édité]
    J'ai réussi a résoudre le problème d'ID en modifiant mon code, je renseigne dans ma requête les colonnes a utiliser en oubliant la colonne d'index (id), elle est assez grande pour se démerder toute seul
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $con->query("INSERT INTO yves2 (nom,prenom,num,rue,code,localite,gsm,tel,pwd,adresse_mail,affil,val) VALUES('".$nom."', '".$prenom."', '".$num."', '".$rue."', '".$code."', '".$localite."', '".$gsm."', '".$tel."', '".$pwd_sha1."', '".$adresse_mail."', '".$affil."', '".$val."')");
    mais il me reste mon soucis assignation de colonnes "vachar" "char" "int"

    Solution de dépannage en attendant de trouver mieux, cela remplace les valeurs "inexistantes" par un zéro, c'est pas très propre, mais cela fonctionne !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    if ($num == NULL){
         $num = '0';}
    if ($code == NULL){
         $code = '0';}	
    if ($gsm == NULL){
         $gsm = '0';}
    if ($tel == NULL){
         $tel = '0';}
    if ($affil == NULL){
         $affil = '0';}

  10. #10
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    tu ne vas surtout pas tout passer en varchar sinon je te casse les doigts ;-)
    la programmation est faite pour s'adapter au terrain, donc il faut coder de manière à ce que le PHP s'adapte à la base de données qui elle est beaucoup plus rigide.
    Indique les colonnes différentes de varchar ou char, stp.

    Tu dois aussi utiliser les mécanismes de protection des données fournis par le moteur de la base de données (requêtes préparées) et pas les remplacer par ceux relatifs à la protection du rendu html (htmlspecialchars...)

  11. #11
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    voici comment est ma table
    id int(3) Non Aucun(e) AUTO_INCREMENT
    nom varchar(20) utf8_general_ci Non NULL
    prenom varchar(20) utf8_general_ci Non
    num int(8) Oui NULL
    rue varchar(30) utf8_general_ci Oui NULL
    code int(8) Oui NULL
    localite varchar(50) utf8_general_ci Non Aucun(e)
    gsm text(20) Non Aucun(e)
    tel text(20) Non Aucun(e)
    pwd varchar(50) utf8_general_ci Non
    adresse_mailvarchar(100) utf8_general_ci Non
    affil int(9) Non Aucun(e)
    val tinyint(1) Non Aucun(e)
    je l'avais écris dans le post précédent :
    Citation Envoyé par Alain
    je peux tout mettre en type "vachar", sauf l' ID a cause de l'incrémentation qui ne fonctionne pas en type "vachar"
    mais cela ne serait pas logique, les colonnes destinées a recevoir des nombres doivent être définies comme telle.
    et voilà, je garde tous mes doigts (pas cassés).

    en attendant de trouvé mieux, je remplace les champs vides par des zéros et cela fonctionne très bien !

  12. #12
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    je ne comprends pas ta définition de table :
    - Non Aucun(e)
    - Oui NULL
    Tu ne pourrais pas poster directement la DDL ?

  13. #13
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    Tu ne pourrais pas poster directement la DDL
    je ne savais pas ou la trouver.

    mais, j'ai fini par trouver.
    Code sql : 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
    CREATE TABLE `yves2` (
     `id` int(3) unsigned NOT NULL AUTO_INCREMENT,
     `nom` varchar(20) NOT NULL,
     `prenom` varchar(20) NOT NULL,
     `num` int(8) NOT NULL,
     `rue` varchar(30) NOT NULL,
     `code` int(8) NOT NULL,
     `localite` varchar(50) NOT NULL,
     `gsm` text NOT NULL,
     `tel` text NOT NULL,
     `pwd` varchar(50) NOT NULL,
     `adresse_mail` varchar(100) NOT NULL,
     `affil` int(9) NOT NULL,
     `val` tinyint(1) NOT NULL,
     PRIMARY KEY (`id`),
     KEY `id` (`id`),
     KEY `id_2` (`id`)
    ) ENGINE=MyISAM AUTO_INCREMENT=128 DEFAULT CHARSET=utf8

  14. #14
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    je ne comprends pas pourquoi tu as mis toutes les colonnes en NOT NULL ? Toutes les colonnes sont obligatoires ?

  15. #15
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    j'ai essayé plein de configurations différentes et de plus il est difficile de trouver des explications détaillée en français sur ce sujet.
    si tu as un liens, je suis preneur.

    mais si je les configure en NULL , elles n’acceptent quand même pas les champs vides.

  16. #16
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Quelles sont les colonnes obligatoires et celles qui sont facultatives.

  17. #17
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    Les obligatoires sont :
    nom
    prénom
    pwd
    adresse_mail
    val
    toutes le autres sont facultatives et c'est tout le problème, les colonnes "num" et "code" sont configurées "int()", et de ce fait elles n'acceptent pas de ne pas recevoir une valeur.
    dès que j'ajoute ceci dans mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    if ($num == NULL) {
        $num = '0';	}
    if ($code == NULL) {
        $code = '0';}
    cela fonctionne, mais ça écrit un zéro dans la colonne

  18. #18
    Membre émérite Avatar de Geoffrey74
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2007
    Messages
    515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2007
    Messages : 515
    Par défaut
    Salut,

    pour le champs int nul, tu peux définir dans ta table, une valeur par défaut.
    Ainsi, si aucune valeur n'est saisie, la valeur par défaut prendra le relais.

  19. #19
    Membre averti
    Homme Profil pro
    amateur passionné
    Inscrit en
    Février 2018
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 65
    Localisation : Belgique

    Informations professionnelles :
    Activité : amateur passionné

    Informations forums :
    Inscription : Février 2018
    Messages : 20
    Par défaut
    et non, quand je mets une valeur par défaut (0), si le champ est vide, le script ne bloque pas, j'ai le message "données enregistrées" qui s'affiche, mais en réalité, les données ne le sont pas.

  20. #20
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Une version comme une autre :
    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
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    $data   = [];
    $errors = [];
     
    $check_value_str = function(string $post_key, bool $required, bool $empty_allowed, string $control_name, string $db_field = '', int $min_length = null, int $max_length) use (&$data, &$errors)
    {
        if ($db_field === '') {
            $db_field = $post_key;
        }
     
        if (isset($_POST[$post_key])) {
            if ($_POST[$post_key] === '') {
                if ($empty_allowed === false) {
                    $errors[] = $control_name.' invalide';
                    return;
                }
            } else {
                if ($min_length !== null) {
                    if (mb_strlen($_POST[$post_key]) < $min_length) {
                        $errors[] = $control_name.' : valeur trop courte';
                        return;
                    }
                }
                if ($max_length !== null) {
                    if (mb_strlen($_POST[$post_key]) > $max_length) {
                        $errors[] = $control_name.' : valeur trop longue';
                        return;
                    }
                }
     
                $data[$db_field] = $_POST[$post_key];
            }
        } elseif ($required) {
            $errors[] = $control_name.' obligatoire';
        }
    };
     
    $check_value_int = function(string $post_key, bool $required, string $control_name, string $db_field = '', int $min = null, int $max = null) use (&$data, &$errors) {
        if ($db_field === '') {
            $db_field = $post_key;
        }
     
        if (isset($_POST[$post_key]) && ($_POST[$post_key] !== '')) {
            if (ctype_digit($_POST[$post_key]) === false) {
                $errors[] = $control_name.' : numérique attendu';
                return;
            } else {
                if ($min !== null) {
                    if ($_POST[$post_key] < $min) {
                        $errors[] = $control_name.' : valeur supérieure attendue';
                        return;
                    }
                }
                if ($max !== null) {
                    if ($_POST[$post_key] > $max) {
                        $errors[] = $control_name.' : valeur inférieure attendue';
                        return;
                    }
                }
     
                $data[$db_field] = (int)$_POST[$post_key];
            }
        } elseif ($required) {
            $errors[] = $control_name.' : valeur obligatoire';
        }
    };
    // obligatoire
    $check_value_str('nom', true, false, 'Nom', '', 1, 20);
    $check_value_str('prenom', true, false, 'Prénom', '', 1, 20);
    $check_value_str('pwd', true, false, 'Mot de passe', '', 1, 50);
    $check_value_str('adresse_mail', true, false, 'Email', '', 1, 100);
    $check_value_int('val', 'int', true, 'Valeur', 0, 9);
    // facultatif
    $check_value_int('num', 'int', false, 'Numéro', 0, 99999999);
    $check_value_str('rue', false, true, 'Rue', '', 0, 30);
    $check_value_int('code', 'int', false, 'Code postal', 0, 99999999);
    $check_value_str('localite', false, true, 'Localité', '', 0, 50);
    $check_value_str('gsm', false, true, 'GSM');
    $check_value_str('tel', false, true, 'Téléphone');
    $check_value_int('affil', 'int', false, 'Affiliation', 0, 999999999);
     
    if ( ! empty($errors)) {
        echo implode('<br>', $errors);
        exit;
    }
     
    if (empty(filter_var($data['adresse_mail'], FILTER_VALIDATE_EMAIL))) {
        echo 'Adresse email invalide';
        exit;
    }
     
    // sql
    $values = [];
    foreach ($data as $db_fields => $v) {
        $values[] = is_int($v) ? $v : '?';
    }
     
    $sql  = 'INSERT INTO yves2 ('.implode(', ', array_keys($data)).') VALUES ('.implode(', ', $values).')';
    $stmt = $con->prepare($sql);
    $exec = $stmt->execute($data);
     
    if ($exec) {
        // réussite
    } else {
        // échec
    }
    Remplace dans toutes le colonnes facultatives NOT NULL par DEFAULT NULL;
    Essaie et je croise les doigts

Discussions similaires

  1. Réponses: 1
    Dernier message: 22/02/2018, 01h20
  2. Les formulaires HTML et PHP5
    Par Community Management dans le forum Langage
    Réponses: 3
    Dernier message: 05/05/2013, 12h55
  3. Les formulaires sous le portal d'oracle
    Par nic211 dans le forum Oracle
    Réponses: 16
    Dernier message: 05/07/2004, 16h19
  4. []Problème avec les formulaires Outlook
    Par Invité dans le forum Outlook
    Réponses: 6
    Dernier message: 05/12/2002, 09h59

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