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 :

une idée pour resoudre ce petit pb


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Juin 2010
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 28
    Par défaut une idée pour resoudre ce petit pb
    Bonjour,
    je suis en train d'effectuer mon Projet de Fin d’Étude qui consiste a développer une application php.
    voici mon problème:
    Un utilisateur doit entrer une formule dans un formulaire et puis je dois calculer cette formule,voici un exemple de formule:
    (MoyenneMath+((MoyenneS1+MoyenneS2)/2)+age+NotePFE)/8
    1)un utilisateur peut entrer "MoyMath" au lieu de "MoyenneMath"
    2)MoyenneMath,MoyenneS1, MoyenneS2, age et NotePFE sont des champs de la base de donnée
    3)la longueur de la formule est variable

    et voici ma solution(que je trouve pas satisfaisante):

    1)demander a l'utilisateur le nombre des operateurs/operandes(exp:N) présent dans la formule
    2)lui afficher N inputs de type select soit contenant les champs possible(MoyenneMath,age, ...) soit contenant des opérateurs ==>eviter les fautes de frappes en plus facile a calculer la formule

    j’espère que j'ai été claire et j'espère que vous pouvez m'aidez

  2. #2
    Membre émérite Avatar de vorace
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2010
    Messages
    573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2010
    Messages : 573
    Par défaut
    pourquoi pas faire une sorte de calculatrice en ajoutant des boutons correspondant aux champs de ta base en plus des boutons classiques (+, -, *, 0, 2, (,...) avec une texte area qui afficherai la formule au fur et à mesure que l'opérateur clique sur les boutons...?

  3. #3
    Membre averti
    Inscrit en
    Juin 2010
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 28
    Par défaut
    merci vorace pour la réponse,

    en effet,ta solution est très proche de la mienne,je pense pas que j'arriverai a les appliquer car:
    après avoir utiliser cette calculatrice,la formule introduite(le résultat) sera présente dans un input "Text" par exemple,ensuite je doit appeler une fonction "CalculerFormule" qui reçoit en paramètre une variable "$Formule" et une autre "$IdEtudiant" qui permet de calculer la formule passer en paramètre pour l’étudiant donné et retourne le résultat.

    la question est comment appliquer la formule qui est une chaine de caractères?

  4. #4
    Membre Expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Par défaut
    Salut

    Le principe de la calculatrice qu'à suggéré Vorace me parais pourtant une bonne solution, car on évite justement que l'utilisateur ne saisisse une chaine, avec tous les éventuels erreurs, et les possibilités tel que MoyenneMath/MoyMath qui ne font que rajouter de la complexité pour rien.

    Pour ça, Javascript serait fort utile.
    En gros, imaginons que coté interface/graphique on simule une calculatrice, dont chaque bouton représente la donnée à générer.
    un bouton "MoyMath" -> va générer MoyenneMath
    un bouton"(" -> va générer l'ouverture d'une parentèse
    -> ) -> fermeture d'une parentèse
    -> idem pour + - * / etc, etc ... tout ce qu'il faut en faite.

    Ensuite, pour aider l'utilisateur, on crée une zone de texte qui sera là juste pour visualiser les opérations (comme une calculatrice), du coup, même avec l'impossibilité de saisir quoi que ce soit (on rajoute : readonly="readonly").

    Et bien chaque click sur un des bouton va déclencher la fonction JS en relation, et ces fonctions génèreraient des champs cachés avec sa valeur, mais aussi va rajouter cette même valeur dans le champ texte.

    Un 1er click sur le bouton : (
    Puis sur : MoyMath
    Puis : +
    On génèrerait successivement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <input type="hidden" name="formule[0]" value="(" />
    <input type="hidden" name="formule[1]" value="MoyenneMath" />
    <input type="hidden" name="formule[2]" value="+" />
    Et sur le champ texte on verrait afficher au fur et à mesure : (MoyenneMath+

    Et à la validation, on recevra en POST un tableau du nom de "formule", et une simple boucle foreach permettra de générer la chaine de requête finale.

    Obtenir tout ça dans un tableau est un gros avantage à mon sens, ça évite des successions de REGEX souvent complexes pour vérifier si tout ça est permis et cohérent.


    C'est une idée.

  5. #5
    Membre averti
    Inscrit en
    Juin 2010
    Messages
    28
    Détails du profil
    Informations forums :
    Inscription : Juin 2010
    Messages : 28
    Par défaut
    Salut RunCodePhp,

    merci pour l'idée mais la question qui se repose est comment utiliser la formule dans ma fonction "CalculerFormule" ?
    j'explique :

    function CalculerFormule($idEtudiant,$Formule)
    {
    //suposant que $Formule vaut "(age+MoyMat)/2" (chaine de caractere)
    //1) je doit extraire "age" et "MoyMat" de la chaine $Formule
    //2) je doit consulter ma base de donnée et recuperer l'age et la moy pour
    //l'idEtudiant passer en parametre(un simple select )
    //==>j'ai donc $age(exemple 20) et $MoyMath(10)
    $resultat=(age+MoyMat)/2; //comment faire
    return $reultat; // ==>retourne 15
    c'est claire ou pas?

  6. #6
    Membre émérite Avatar de vorace
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2010
    Messages
    573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2010
    Messages : 573
    Par défaut
    une fonction java sur l'événement onclick de chaque bouton avec un innerHTML qui écrira dans le champs texte le nom du bouton correspondant qui sera au fait le nom de tes champs de bdd avec en plus un champs hidden dans le quel tu écris la même chose mais avec un '$' devant chaque nom, une fois validé tu récupère le contenu du champ, tu effectues tes requêtes pour récupérer tes champs que tu affectes à des variables de même nom que celles contenues dans ton input hidden et avec cette ligne ca devrai être bon :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    eval('$result ='.$_POST['calcul'].';');
    calcul étant le nom de l'input hidden...je sais c'est pas très simple et cette ligne niveau sécurité c'est pas top mais bon...ca devrait marcher.
    RunCodePhp m'a devancé de quelques minutes mais l'idée est la même et la sienne me parait plus propre...

  7. #7
    Membre Expert Avatar de RunCodePhp
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    2 962
    Détails du profil
    Informations personnelles :
    Localisation : Réunion

    Informations forums :
    Inscription : Janvier 2010
    Messages : 2 962
    Par défaut
    @vorace
    Un eval sur une donnée en POST ... mouais ...

    Est-ce si compliqué que ça de générer des champs cachés qui au bout donne un bon vieux tableau :
    $_POST['formule'][0] -> (
    $_POST['formule'][1] -> MoyenneMath
    $_POST['formule'][2] -> +
    ... etc ...

  8. #8
    Membre émérite Avatar de vorace
    Homme Profil pro
    Développeur
    Inscrit en
    Août 2010
    Messages
    573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Août 2010
    Messages : 573
    Par défaut
    @RunCodePhp
    j'ai bien dit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    calcul étant le nom de l'input hidden...je sais c'est pas très simple et cette ligne niveau sécurité c'est pas top mais bon...ca devrait marcher.
    et si tu lis le message jusqu'au bout tu verras que je préconise ta méthode...
    et il est vrai que implicitement je supposais en dépit de la loi de Murphy que l'appli serait en intranet et que l'utilisateur ne serait pas assez tordu pour tenter quoi que ce soit...

  9. #9
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Citation Envoyé par RunCodePhp Voir le message
    @vorace
    Un eval sur une donnée en POST ... mouais ...
    J'aurais même tendance à dire un eval tout court ^^

    Puisque les données à calculer semble extraite d'une bdd et si cette application n'a pas d'impératif de sécurité , le fait de cliquer sur les boutons de la calculette (idée qui me semble également intéressante) pourrait simplement construire la requete de calcul.

    Lorsque l'on appui sur égale cela execute simplement la requête du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $formule = mysql_real_escape_string($_POST['formule']);
    $sql = mysql_query('SELECT '.$formule.' as resultat FROM matable WHERE idUtilisateur = '.intval($_POST['id']));
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

Discussions similaires

  1. Une idée pour le développement d'un petit jeu ?
    Par funkydata dans le forum NxEngine
    Réponses: 28
    Dernier message: 01/06/2007, 13h54
  2. Réponses: 50
    Dernier message: 12/04/2007, 11h04
  3. [eCommerce] Une idée pour un script ?
    Par samoth dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 31/07/2006, 09h49
  4. Une idée pour un débutant
    Par poutine dans le forum C
    Réponses: 15
    Dernier message: 04/05/2006, 21h54
  5. Une idée pour utiliser ce type de fichier data??
    Par Frenchy dans le forum DirectX
    Réponses: 2
    Dernier message: 14/02/2006, 13h24

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