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

Python Discussion :

Decodage d'un texte crypté en vigenere


Sujet :

Python

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Novembre 2011
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Novembre 2011
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Decodage d'un texte crypté en vigenere
    Bonjour, j'ai pu créer un programme pour coder en vigenere mais je ne trouve pas de solution pour décoder la phrase obtenue. Voici mon programme de codage. Pouvez-vous m'aider ?? Merci d'avance

    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
    # Construction du carré de Vigenère
    Carre=[]
    ligne=[] 
    for j in range(26):
        for i in range(26):
            ligne.append(chr(65+(i+j)%26)) # chr donne la lettre a partir du numero ASCII
        Carre.append(ligne)
        ligne=[]
     
    # Initialisation des données    
    TexteClair=raw_input("Entrer le texte(en majuscule):") #En majuscule uniquement
    lg_tc=len(TexteClair)
    Cle=raw_input("Entrer la clef(en majuscule):") #En majuscule uniquement
    lg_C=len(Cle)
    bl=0                   # variable pour stockage du nombre d'espaces
    TexteCrypte=""
     
    # Cryptage
    for i in range(lg_tc):
        lettre=TexteClair[i]
        if lettre==" ":
            bl+=1
            TexteCrypte+=" "
        else:
            j=(i-bl)%lg_C           # % sert a inserer les valeurs dans la chaine
            k=ord(Cle[j])-65        #ord sert a donner le chiffre correspondant a la lettre dans la table ASCII
            h=ord(lettre)-65
            TexteCrypte+= Carre[h][k]
     
    # Affichages
    print "             Texte de départ :"
    print TexteClair
    print "             Clé :"
    print Cle
    print "             Texte crypté :"
    print TexteCrypte

  2. #2
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 689
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par renard_473 Voir le message
    Bonjour, j'ai pu créer un programme pour coder en vigenere mais je ne trouve pas de solution pour décoder la phrase obtenue.
    Salut

    Le code de Vigenère n'est qu'un simple code de César. La seule différence, c'est que chaque lettre est chiffrée sur un alphabet ou un autre donné par la clef.

    Donc pour l'alphabet "1", le A deviendra B, le B deviendra C etc. En sens inverse, le B devient A, le C de vient B etc.

    Citation Envoyé par renard_473 Voir le message
    Voici mon programme de codage. Pouvez-vous m'aider ?? Merci d'avance

    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
    # Construction du carré de Vigenère
    Carre=[]
    ligne=[] 
    for j in range(26):
        for i in range(26):
            ligne.append(chr(65+(i+j)%26)) # chr donne la lettre a partir du numero ASCII
        Carre.append(ligne)
        ligne=[]
     
    # Initialisation des données    
    TexteClair=raw_input("Entrer le texte(en majuscule):") #En majuscule uniquement
    lg_tc=len(TexteClair)
    Cle=raw_input("Entrer la clef(en majuscule):") #En majuscule uniquement
    lg_C=len(Cle)
    bl=0                   # variable pour stockage du nombre d'espaces
    TexteCrypte=""
     
    # Cryptage
    for i in range(lg_tc):
        lettre=TexteClair[i]
        if lettre==" ":
            bl+=1
            TexteCrypte+=" "
        else:
            j=(i-bl)%lg_C           # % sert a inserer les valeurs dans la chaine
            k=ord(Cle[j])-65        #ord sert a donner le chiffre correspondant a la lettre dans la table ASCII
            h=ord(lettre)-65
            TexteCrypte+= Carre[h][k]
     
    # Affichages
    print "             Texte de départ :"
    print TexteClair
    print "             Clé :"
    print Cle
    print "             Texte crypté :"
    print TexteCrypte
    Le "carré" c'est bon quand on le fait à la main... pour éviter de reconstuire un alphabet à chaque lettre qu'on chiffre ou qu'on déchiffre. Mais en programmation on peut utiliser des raccourcis. Tu aurais décomposé en réfléchissant sur la façon dont fonctionne réellement Vigenère tu y serais arrivé tout seul. Et en plus tu aurais remarqué qu'on peut aussi chiffrer les éléments significatifs comme la ponctuation ou les espaces...
    Code python : 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
    #!/usr/bin/env python
    # -*- coding: UTF-8 -*-
     
    import string
     
    # Fonction qui chiffre/déchiffre une lettre en fonction d'un alphabet donné et d'une base de décalage
    def Vigenere(alphaN, base, lettre, crypt=True):
    	# Recherche position de la base dans l'alphabet
    	ind=alphaN.find(base)
     
    	# Si base non trouvée, alors alphabet chiffré identique à alphabet donné
    	if ind == -1: ind=0
     
    	# Création de l'alphabet chiffré à partir de l'alphabet normal et de la base
    	alphaK="".join([alphaN[(ind + i) % len(alphaN)] for i in range(len(alphaN))])
     
    	# Positionnement du masque de conversion en fonction du sens (chiffrage/déchiffrage)
    	masque=(alphaN, alphaK) if crypt else (alphaK, alphaN)
     
    	# Recherche index lettre dans le masque de départ
    	ind=masque[0].find(lettre)
     
    	# Si lettre n'appartient pas à l'alphabet on la renvoie telle quelle. Elle ne sera pas chiffrée mais ne plantera pas la fonction
    	if ind == -1: return lettre
     
    	# Renvoi lettre associée du masque d'arrivée
    	return masque[1][ind]
    # Vigenere
     
    # Création de l'alphabet à partir de tous les caractères imprimables de la table ascii (majuscules, minuscules, chiffres, ponctuation, ...)
    alpha="".join([chr(i) for i in range(256) if chr(i) in string.printable])
     
    # Clef
    clef="bonjour"
     
    # Test de chiffrage sur clef
    secret="".join(
    	[Vigenere(alpha, clef[i % len(clef)], x) for (i, x) in enumerate("Les sanglots longs des violons de l'automne, bercent mon coeur d'une langueur monotone !!!")]
    )
    print "Chiffre: [%s]" % secret
    print
     
    # Test de déchiffrage (même clef)
    print "Clair: [%s]" % "".join(
    	[Vigenere(alpha, clef[i % len(clef)], x, False) for (i, x) in enumerate(secret)]
    )
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. [Cryptage] Récupérer Date cryptée dans fichier text
    Par SansSucre dans le forum Access
    Réponses: 2
    Dernier message: 29/07/2006, 13h03
  2. afficher du texte
    Par Mau dans le forum OpenGL
    Réponses: 10
    Dernier message: 24/06/2003, 15h31
  3. fichier binaire ou texte
    Par soussou dans le forum C++Builder
    Réponses: 4
    Dernier message: 14/06/2002, 13h39
  4. Réponses: 2
    Dernier message: 10/06/2002, 11h03

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