begin process at 2010 07 29 15:41:43
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Sécurité & cryptage

 > CHIFFRE DE VIGENÈRE

CHIFFRE DE VIGENÈRE


 Description

Cliquez pour voir la capture en taille normale
Bonjour à tous ! Face au nombre un peu faiblard de codes disponibles en Python, j'ai décidé de déposer quelques-unes de mes sources sur le site, histoire d'enrichir un peu les catégories. Enfin on va essayer :)

Première source : un simple chiffreur / déchiffreur basé sur le chiffre de Vigenère, fonctionnant sur les codes ASCII. Un classique.

Source

  • # -*- coding:Latin-1 -*-
  • entree = raw_input("Chaine a traiter : ")
  • while entree != "quit":
  • cle = raw_input("Cle a utiliser : ")
  • operation = raw_input("Coder / decoder ? (1/2)")
  • sortie, i = "", 0
  • for caract in entree: #parcours de la chaîne à traiter
  • if operation == "1": #chiffrement
  • sortie = sortie + chr((ord(caract) + ord(cle[i])) % 256)
  • i = i + 1 #parcours de la clé
  • if i > len(cle) - 1:
  • i = 0 #fin de clé atteinte, on repart au début
  • elif operation == "2": #déchiffrement
  • sortie = sortie + chr((ord(caract) - ord(cle[i])) % 256)
  • i = i + 1
  • if i > len(cle) - 1:
  • i = 0
  • print entree,"\n",cle,"\n",sortie,"\n"
  • entree = raw_input("Chaine a traiter : ")
# -*- coding:Latin-1 -*-
entree = raw_input("Chaine a traiter : ")
while entree != "quit":
	cle = raw_input("Cle a utiliser : ")
	operation = raw_input("Coder / decoder ? (1/2)")
	sortie, i = "", 0
	for caract in entree:	#parcours de la chaîne à traiter
		if operation == "1":	#chiffrement
			sortie = sortie + chr((ord(caract) + ord(cle[i])) % 256)
			i = i + 1	#parcours de la clé
			if i > len(cle) - 1:
				i = 0	#fin de clé atteinte, on repart au début
		elif operation == "2":	#déchiffrement
			sortie = sortie + chr((ord(caract) - ord(cle[i])) % 256)
			i = i + 1
			if i > len(cle) - 1:
				i = 0
	print entree,"\n",cle,"\n",sortie,"\n"
	entree = raw_input("Chaine a traiter : ")


 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources de la même categorie

Source avec Zip CRYPTEUR CARRE DE POLYBE par Dipx
Source avec une capture HORAIRESRESTREINTS par lonewolfs
Source avec Zip HIDS EN PYTHON par KimbleMandel
CRYPTEUR EN PYTHON par tallgenius
STEGANOGRAPHIE par Marnage

 Sources en rapport avec celle ci

Source avec Zip CRYPTEUR CARRE DE POLYBE par Dipx
Source avec Zip Source avec une capture LES CONTES DE MONTE CRYPTO par amaury74
STEGANOGRAPHIE par Marnage
Source avec une capture CRYPTAGE AVEC LE CHIFFRE DE CÉSAR par ara3n
Source avec Zip Source avec une capture CHIFFRE DE VIGENÈRE par benitoelputoamo

Commentaires et avis

Commentaire de doudou3158 le 12/05/2007 19:16:03

Pourrai-tu détailler ce passega stp :

sortie = sortie + chr((ord(caract) + ord(cle[i])) % 256)

Je sais que ord() retourne la valeur ascii d'un caractère et que chr() et sont contraire.

Et puis cette ligne ci aussi :

sortie, i = "", 0

Désolé je suis débutant en python..

Commentaire de doudou3158 le 12/05/2007 19:18:33

Dsl pour le double post, mais en faite ce qui me gene c'est le %256 je comprend pas ce qui vien faire la...

Commentaire de VladislavIV le 15/05/2007 09:31:35

Bien sûr !
sortie, i = "", 0 est une série d'affectations. J'aurai pu écrire
sortie = ""
i = 0

% est l'opérateur "modulo" : x % y renvoie le reste de la division de x par y.

chr( ( ord(caract) + ord(cle[i]) ) % 256 )

L'objectif est d'obtenir un caractère codé, en faisant la "somme" d'un caractère en clair et d'un caractère de la clé.
clair + clé = code
J'additionne donc les codes ascii, puis je fais % 256 pour obtenir une valeur entre 0 et 256 -> on retombe sur la table ascii. On peut alors utiliser chr() pour obtenir le caractère correspondant, codé.

En espérant être clair ;)

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Cryptage DES [Python] [ par Kadaj676 ] Bonjour j'aimerais savoir si vous aviez de la documentation sur des algo's de cryptage. Principalement DES, et je voudrais vosu demander, si il est po Cryptage xor [ par sorcier0011 ] Bonjour,J'aimerais bien faire un petit crypteur de texte xor mais je n'arrive pas a trouver comment convertir des lettres en Ascii. Parce que apart fa [Programme Python] Cryptage RSA (cherche codeur) [ par GelH ] Bonjour, Je recherche un codeur Python capable de réaliser un programme de cryptage/décryptage d'une chaine de caractère utilisant l'algorithme RSA.


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Juillet 2010
LMMJVSD
   1234
567891011
12131415161718
19202122232425
262728293031 

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,952 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales