aspeum Posté 5 Novembre 2007 Posté 5 Novembre 2007 Bonjour, Je travaille au sein d'une structure associative, et je suis notamment chargé de réaliser les sites web. Par nécessité, j'ai appris PHP sur le tas, et plus j'avance, plus j'ai l'impression que certaines de mes bases sont mauvaises pour avancer. A commencer par quelque chose de tout simple : la récupération de données d'un formulaire ! La méthode que j'utilise actuellement - et qu'on m'avait présenté comme particulièrement élégante - était de faire le formulaire et la récupération/analyse des données dans un seul fichier. En gros, le fichier commence par un "if" pour voir si le bouton a été validé, et si oui, il analyse les données, si non, il affiche le formulaire. Mais à l'usage, je trouve ça incroyablement compliqué, d'autant plus que ce formulaire est particulièrement long. Et comme je dois aussi rajouter des tests sur les données soumises par l'utilisateur pour lui réafficher le formulaire en cas d'erreur, j'arrive à un fichier final que j'ai peur de modifier... Que pensez-vous de cette méthode ? Est-elle pertinente ? Existe-t-il d'autres méthodes ? Merci d'avance pour toute réponse.
Keyser Posté 5 Novembre 2007 Posté 5 Novembre 2007 Salut, Oui c'est la méthode que j'utilise également. En fait lorsque l'envoi du formulaire est validé, tu peux utiliser la fonction header si tu veux alléger ta page et des variables de session pour transmettre tes variables de page en page. D'une manière générale, je te conseille de regrouper au maximum les actions (vérification des données postées, affichage des messages d'erreur, etc.) et d'utiliser des fonctions que tu pourras réutiliser plus tard pour gagner du temps. L'important finalement, ce n'est pas tellement les méthodes quer tu choisis, c'est que tu t'y retrouves et que tu arrives à faire ce que tu veux.
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 D'un côté, tu me rassures, je n'utilise pas une méthode absurde... D'un autre, ça m'inquiète, puisque je rame un peu... Je pense effectivement que je n'automatise pas assez certaines fonctions... Qu'entends-tu par "utiliser la fonction header si tu veux alléger ta page et des variables de session pour transmettre tes variables de page en page" ?
xunil Posté 5 Novembre 2007 Posté 5 Novembre 2007 Une petite introduction pour bien saisir les bases... http://www.scriptol.org/ecmascript/php.php On peut aussi utiliser Ajax avec la méthode post. J'arrive à passer le contenu d'un RSS comme çà, donc un bloc de données assez gros en paramètre.
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 Merci pour ce document. A le lire, j'ai l'impression que je suis sur la bonne voie, pourtant... Deux questions : - Contrôler des champs via du JavaScript ou de l'AJAX (y a-t-il une différence ?), ça pourrait m'être utile... Une ressource pour débuter là-dedans ? - Mettons que je reste en PHP pur. J'ai un premier formulaire, court, qui donne accès à un deuxième formulaire, plus long, qui dépend des données du premier formulaire (les champs sont différents). Dans les deux formulaires, j'ai des contrôles (en PHP, donc après validation) sur certains champs, qui font réafficher le questionnaire en cas d'erreur de saisie. J'ai toujours l'impression que certaines valeurs se perdent en route... Y a-t-il des astuces pratiques ? A chaque fois que je trouve des tutoriels, c'est sur des exemples très simples, mais ma configuration l'est beaucoup moins...
Sarc Posté 5 Novembre 2007 Posté 5 Novembre 2007 Bonjour, Ce qui est important dans ton fichier, c'est de bien séparer les différentes zones. Par exemple : if (formulaire envoyé)elseif (page 2)else (= page 1) Ensuite, n'hésite pas à faire des gros blocs de commentaires entre chaque partie pour bien séparer... Quitte à faire un pavé de # : ###################################################################################################################### ########## Partie 2 du formulaire ###################### ########################################################### ########################################################### Après, tu te repères assez bien dans ton programme, et ce qui te paraissait long et compliqué à modifier devient finalement plus sectionné, donc plus agréable à travailler. Ensuite, dans ton traitement en PHP, tu dois essayer aussi de bien fractionner chaque petite vérification. A chaque fois, mets un commentaire pour une relecture très rapide de ton programme. Au final, tu as quelque chose qui sera peut-être de 25ko de texte, mais qui sera assez lisible pour le modifier aisément.
xunil Posté 5 Novembre 2007 Posté 5 Novembre 2007 Pour la première question, faire un contrôle sur les données entrées est très facile mais cela dépend de ce que l'on contrôle, s'il faut faire des vérifications dans une base de données, il faudrait utiliser Ajax + PHP. Sinon, un exemple: HTML: onclick="mafonction(this)" JavaScript function mafonction(element) { var x = element.monid; if(x < 1 || x > 5) alert("la valeur doit être comprise entre 1 et 5"); } Pour la seconde question, on peut utiliser un include, on ne perdra aucune donnée.
Keyser Posté 5 Novembre 2007 Posté 5 Novembre 2007 Qu'entends-tu par "utiliser la fonction header si tu veux alléger ta page et des variables de session pour transmettre tes variables de page en page" ? Pour la fonction Header, c'est simple, le code suivant te permet de changer de page : <?php header("location: autrepage.php"); ?>. Tu auras plus d'infos à cette adresse : php.net/header. (Juste une précaution pour cette fonction, il ne faut pas mettre de code html avant, pour que ça marche.) Pour comprendre les sessions je te conseille l'article du site du zéro sur le sessions php. D'ailleurs je te conseille les cours php de ce site.
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 _AT_sarc : D'accord. Le sentiment que j'ai vient peut-être de l'absence de clarté de mon document, c'est vrai... Pour le moment, les deux parties de mon formulaire sont en fait deux fichiers distincts : c'est une erreur ?
Sarc Posté 5 Novembre 2007 Posté 5 Novembre 2007 Ce n'est pas une "erreur", l'important est que tu et retrouves dans tes fichiers, et qu'il soit clairement possible pour toute autre personne (même si tu comptes pas céder ton site) de pouvoir relire et comprendre ton programme ! Il est aussi possible d'utiliser la fonction "include" pour ajouter les parties du formulaire qui t'intéressent, et mettre ces deux parties dans d'autres fichiers, pour alléger la taille du fichier... Bref, tout est possible ! Par contre, j'ai déjà vu quelqu'un qui a fait un formulaire en 6 programmes, et j'ai trouvé ça un petit peu abusé. Mais bon...
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 _AT_xunil : D'accord, merci pour l'exemple du JavaScript. _AT_Keyser : Je croyais que les variables de session n'étaient utilisables qu'en cas de connexion via login + mot de passe. Et c'est ce que semble indiquer le cours du site du zéro... J'ai mal compris ? Merci en tous cas pour les conseils, je vais essayer d'améliorer tout ça. Ah, une autre question, pas tant technique qu'ergonomique : pour indiquer à l'utilisateur qu'un champ n'a pas été rempli, ou qu'il contient une erreur, quel est la manière la plus efficace ? Un message d'alerte JavaScript ? Une insertion de texte HTML ? Une autre manière dont j'ignore l'existence ?
Sarc Posté 5 Novembre 2007 Posté 5 Novembre 2007 Un ensemble des deux ? Si la personne n'a pas le javascript activé, il ne verrait rien si tu ne mets que du javascript... En même temps, ça peut être utile de balancer un message "Vous n'avez pas rempli le champ X" et de laisser la page, pour qu'il puisse finir. Mais de toute façon, un traitement en PHP est obligatoire après coup, pour tout vérifier... Donc si en PHP tu te rends compte que le champ est vide, tu n'hésites pas à l'écrire en HTML clairement, et de réafficher le formulaire (pré-rempli avec ses anciens choix, si possible) pour qu'il puisse corriger.
Keyser Posté 5 Novembre 2007 Posté 5 Novembre 2007 (modifié) n'hésite pas à faire des gros blocs de commentaires entre chaque partie pour bien séparer... Quitte à faire un pavé de # Oui je confirme, ça clarifie vraiment les choses et ça ne ralentit pas le programme. Je croyais que les variables de session n'étaient utilisables qu'en cas de connexion via login + mot de passe. Et c'est ce que semble indiquer le cours du site du zéro... J'ai mal compris ? Non ce n'est pas obligé, du moment que tu indiques le session_start en haut des pages, ça marche. Modifié 5 Novembre 2007 par Keyser
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 Ce n'est pas une "erreur", l'important est que tu et retrouves dans tes fichiers, et qu'il soit clairement possible pour toute autre personne (même si tu comptes pas céder ton site) de pouvoir relire et comprendre ton programme !Il est aussi possible d'utiliser la fonction "include" pour ajouter les parties du formulaire qui t'intéressent, et mettre ces deux parties dans d'autres fichiers, pour alléger la taille du fichier... Bref, tout est possible ! Par contre, j'ai déjà vu quelqu'un qui a fait un formulaire en 6 programmes, et j'ai trouvé ça un petit peu abusé. Mais bon... _AT_sarc : D'accord, je comprends. C'est bien ce côté "tout-est-possible" qui me pose problème J'ai parfois du mal à y voir clair sur la meilleure méthode à adopter... Dans mon cas, c'est pas la taille du fichier qui m'effraie, mais la "complexité" du formulaire. Le nombre de paramètres qui varient fait que j'oublie toujours un cas particulier qui finit par poser problème...
captain_torche Posté 5 Novembre 2007 Posté 5 Novembre 2007 Quand un formulaire est mal rempli, j'affiche une liste stylée "erreur" (rouge sombre), avec les éléments à préciser. Dans la mesure du possible, je mets les éléments à remplir en valeur (couleur rouge également).
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 Si la personne n'a pas le javascript activé, il ne verrait rien si tu ne mets que du javascript... En même temps, ça peut être utile de balancer un message "Vous n'avez pas rempli le champ X" et de laisser la page, pour qu'il puisse finir. Mais de toute façon, un traitement en PHP est obligatoire après coup, pour tout vérifier... Le JavaScript ne sera donc qu'un "plus", si je comprends bien, pour avertir tout de suite l'utilisateur. Donc si en PHP tu te rends compte que le champ est vide, tu n'hésites pas à l'écrire en HTML clairement, et de réafficher le formulaire (pré-rempli avec ses anciens choix, si possible) pour qu'il puisse corriger. Dans mon cas, c'est indispensable de réafficher le formulaire avec les données remplies, sinon, je doute que l'utilisateur aie le courage de tout re-remplir à nouveau ! Mais comment faire ?
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 Quand un formulaire est mal rempli, j'affiche une liste stylée "erreur" (rouge sombre), avec les éléments à préciser.Dans la mesure du possible, je mets les éléments à remplir en valeur (couleur rouge également). Cette liste, tu la mets en haut du formulaire, c'est ça ? Mais pour les éléments à remplir, comment fais-tu ? Tu attribues une nouvelle classe CSS à ces éléments ?
Sarc Posté 5 Novembre 2007 Posté 5 Novembre 2007 Pour pré-remplir le formulaire, il suffit d'utiliser les attributs "value" qui servent à ça. L'intérêt d'avoir ton traitement PHP du formulaire en début de ton programme, c'est que pour ton formulaire tu peux mettre ça : echo '<input name="coucou" machintruc value="'.$_POST['coucou'].'">'; Comme ça, le formulaire est pré-rempli avec tout ce qui a été envoyé avant. Ensuite, tu peux toujours jouer sur la valeur... Par exemple, si une valeur est fausse, moi je la supprime (comme ça il n'a pas besoin de le faire), certains comme Captain les mettent en rouge... Après, à toi de voir comment tu veux le mettre, mais en tout cas c'est peu compliqué une fois que tes variables sont bien rangées.
aspeum Posté 5 Novembre 2007 Auteur Posté 5 Novembre 2007 OK, c'est exactement comme ça que je fais. Bon, ce n'est définitivement pas un problème de "méthode" employée, alors, juste de rigueur... Merci beaucoup pour l'aide, je vais replancher dessus.
Leonick Posté 7 Novembre 2007 Posté 7 Novembre 2007 echo '<input name="coucou" machintruc value="'.$_POST['coucou'].'">'; je n'affiche pas directement le contenu de la valeur du _POST, mais après un post traitement, ça évite les problèmes de faille XSSEt ne pas oublier qu'un pré traitement en js est bien, mais le seul vrai traitement sécurisé ne peut se faire que sur le serveur, pas sur le navigateur de l'internaute
Sujets conseillés
Veuillez vous connecter pour commenter
Vous pourrez laisser un commentaire après vous êtes connecté.
Connectez-vous maintenant