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 :

Améliorer un programme : (de)codeur Cassis


Sujet :

Langage PHP

  1. #1
    Invité
    Invité(e)
    Par défaut Améliorer un programme : (de)codeur Cassis
    Bonjour,
    Pour mon premier post, je n'ai aucun soucis. Voir même, que des possibilités.
    Dans le cadre de mon apprentissage solitaire au PHP, j'ai écrits plusieurs petits trucs/machins.
    Maintenant que je suis un peu plus à l'aise, je souhaite améliorer mes programmes.
    Par améliorations, j'entends :
    • amélioration du code
    • simplication du code
    • sécurisation du code

    Ne sachant pas trop comment m'y prendre, je lance un appel à ceux qui ont deux minutes, à ceux qui flânent...

    Le fichier sert à coder/décoder une phrase/mot/lettre par le système cassis (k=6).

    Je ne mets pas le fichier complet... Je reçois à partir d'un input la phrase à coder.


    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
     
    <?php 
    $tableaucode = array ("-","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z","a","b","c","d","e");
    if(!empty($_GET['bouton']))
    {
    	//premier travail verifier si la chaine est vide
     
    	if((!empty($_GET['texte'])))
    	{
    		$codeerreur=0;
    		$code = $_GET['texte'];
    		$tabMot = explode(" " , $code);
    		$nbreTabMot = count($tabMot);
    		$i = 0;
     
    		$txt ="";
    		while ($i < $nbreTabMot) 
    		{
    			$tabLettre = explode("-",$tabMot[$i]);
    			$nbreTabLettre = count($tabLettre);
    			$a = 0;
    			while ($a < $nbreTabLettre) 
    			{
    				$txt .= $tableaucode[$tabLettre[$a]];
    				$a++;
    			}
    			$txt .= " ";
    			$i++;
    		}
     
    	}
    	else 
    	{
    		$codeerreur=1;
    		$resultat="le texte est vide";
    	}
     
     
     
    }
    if(!empty($_GET['bouton1']))
    {
    	//premier travail verifier si la chaine est vide
     
    	if((!empty($_GET['texte1'])))
    	{
    		$codeerreur=0;
    		$code = $_GET['texte1'];
    		$tabMot = explode(" " , $code);
    		$nbreTabMot = count($tabMot);
    		$i = 0;
     
    		$txt ="";
    		while ($i < $nbreTabMot) 
    		{
    			$tabLettre = str_split($tabMot[$i],1);
    			$nbreTabLettre = count($tabLettre);
    			$a = 0;
    			while ($a < $nbreTabLettre) 
    			{
    				echo $tabLettre[$a];
    				$txt .= array_search($tabLettre[$a], $tableaucode);
    				$a++;
    				if($a < $nbreTabLettre )
    				{
    					$txt .= "-";
    				}
    			}
    			$txt .= "  ";
    			$i++;
    		}
     
    	}
    	else 
    	{
    		$codeerreur=1;
    		$resultat="le texte est vide";
    	}
     
     
     
    }
     
    ?>
    La première idée qui me vient serait de n'avoir qu'un seul input. C'est le PHP qui viendrait déterminer si il faut coder ou decoder.
    Le seconde point serait de sécuriser la variable via un preg_match ?

    Qu'en pensez-vous ? Avez-vous d'autres suggestions ?

    Merci et bon surf !

  2. #2
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    Question: "bouton" et "bouton1" peuvent être éxécutée en même temps ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(!empty($_GET['bouton']))
    (...)
    if(!empty($_GET['bouton1']))
    oui pour le
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    preg_match('/^([a-z-]*)$/',$_GET['texte'])
    Plusieurs pistes d'amélioration:
    1. utiliser des conventions de nommage des variable aCode pour variable code de type array, iNbMot (pour variable NbMot de type integer)
    2. factoriser: voir ce qui peut être mutualisé , le principe de DRY (don't repeat yourself )
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

  3. #3
    Invité
    Invité(e)
    Par défaut
    utiliser des conventions de nommage des variable aCode pour variable code de type array, iNbMot (pour variable NbMot de type integer)
    L'idée c'est de nommer les variables pour que l'ont sachent ce qu'elles contiennent et leurs types ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    if((!empty($_GET['texte'])) AND preg_match("/^[0-9\s\-]+$/", $_GET['texte']))
    	{
    ....
    	}
    	elseif((!empty($_GET['texte'])) AND preg_match("/^[a-zA-Z\s\-]+$/", $_GET['texte']))
            {
            }
             else{}
    En effet j'ai ajouté "preg_match" ce qui me permet de n'avoir plus qu'un input. Ca me permet de sécuriser et d'améliorer.

    Je continue à chercher des améliorations.

    Merci pour ce premier retour.

  4. #4
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par pingouincodeur Voir le message
    L'idée c'est de nommer les variables pour que l'ont sachent ce qu'elles contiennent et leurs types ?
    Exact

    Citation Envoyé par pingouincodeur Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    if((!empty($_GET['texte'])) AND preg_match("/^[0-9\s\-]+$/", $_GET['texte']))
    	{
    ....
    	}
    	elseif((!empty($_GET['texte'])) AND preg_match("/^[a-zA-Z\s\-]+$/", $_GET['texte']))
            {
            }
             else{}
    En effet j'ai ajouté "preg_match" ce qui me permet de n'avoir plus qu'un input. Ca me permet de sécuriser et d'améliorer.

    Je continue à chercher des améliorations.

    Merci pour ce premier retour.
    Bien, mais vous n'avez pas répondu à ma question: vous avez deux conditions if pour "bouton" et "bouton1" : peuvent-t-ils etre éxécutée en même temps ?

    Une chose toute bête peut être également de migrer vers une classe
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

  5. #5
    Invité
    Invité(e)
    Par défaut
    Les deux boutons s'expliquent. Le premier etait pour un input "décodage". Le second pour un input "codage".
    Maintenant je n'ai donc plus qu'un seul input. Je répond a votre question ?

    Concernant la classe, cela necessite de la POO ? C'est pour moi une très grande inconnue la POO.

  6. #6
    Rédacteur
    Avatar de imikado
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2006
    Messages
    5 239
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 239
    Points : 19 100
    Points
    19 100
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par pingouincodeur Voir le message
    Les deux boutons s'expliquent. Le premier etait pour un input "décodage". Le second pour un input "codage".
    Maintenant je n'ai donc plus qu'un seul input. Je répond a votre question ?
    Oui c'était ma question

    Citation Envoyé par pingouincodeur Voir le message
    Concernant la classe, cela necessite de la POO ? C'est pour moi une très grande inconnue la POO.
    C'est le moment et la bonne base pour s'y mettre vous y arriverez facilement je pense
    Framework php sécurisé et simple à prendre en main avec générateur web http://mkframework.com/ (hebergé sur developpez.com)
    Mes cours/tutoriaux

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Programmation grafcet codeur-variateur, pl7 pro
    Par wolfazerty dans le forum Automation
    Réponses: 5
    Dernier message: 27/05/2012, 21h52
  2. améliorer mon programme
    Par vivitron dans le forum Débuter
    Réponses: 7
    Dernier message: 03/10/2010, 13h24
  3. améliorer un programme
    Par jacfld49 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 11/02/2010, 22h53
  4. Améliorer un programme très simple
    Par Alp dans le forum Prolog
    Réponses: 6
    Dernier message: 15/03/2008, 11h17
  5. Réponses: 14
    Dernier message: 25/02/2008, 13h47

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