begin process at 2010 02 09 19:07:23
  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 une capture HORAIRESRESTREINTS par lonewolfs
Source avec Zip HIDS EN PYTHON par KimbleMandel
CRYPTEUR EN PYTHON par tallgenius
STEGANOGRAPHIE par Marnage
Source avec une capture CRYPTAGE AVEC LE CHIFFRE DE CÉSAR par ara3n

 Sources en rapport avec celle ci

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 une capture PROTÉGEZ VOS FICHIERS PDF EN UN SIMPLE CLIC par guillaume_pays_cevenol
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


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

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,874 sec (4)

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