begin process at 2012 05 27 19:47:50
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths

 > CRYPTAGE : MÉTHODE DE TRANSPOSITION

CRYPTAGE : MÉTHODE DE TRANSPOSITION


 Information sur la source

Note :
Aucune note
Catégorie :Maths Classé sous :cryptage, décryptage, méthode, transposition, messages Niveau :Débutant Date de création :24/11/2008 Date de mise à jour :25/11/2008 16:39:59 Vu / téléchargé :5 992 / 379

Auteur : bad_dark_spirit

Ecrire un message privé
Site perso
Ce membre participe au partage de revenus publicitaires
Commentaire sur cette source (1)
Ajouter un commentaire et/ou une note


 Description

Cliquez pour voir la capture en taille normale
Le programme suivant crypte/décrypte un message grâce à la méthode de transposition. Vous devez entrer la chaîne de caractère à crypter (ou décrypter), on tape ensuite la clé de cryptage, et on clique sur crypter ou décrypter.

Le programme vérifie la validité de la clé, en effet, la clé doit contenir les chiffres de 1 à 8. Cette méthode divise la chaine en bloc de 8 caractères, transforme les espaces et la fin du dernier bloc avec des '0'. Ensuite les lettres des blocs sont placés dans l'ordre indiqué par le clé de cryptage.

Source

  • ///////////////////////////////////////////////////////////
  • // Fichier : uTransposition.pas //
  • // Auteur : Stéphane Haimet //
  • // Date de création : 01/02/08 //
  • // Date de modification : 15/02/08 //
  • ///////////////////////////////////////////////////////////
  • unit uTransposition;
  • interface
  • uses
  • Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  • Dialogs, StdCtrls, Buttons, uFonctions;
  • type
  • TForm1 = class(TForm)
  • eMessage: TEdit;
  • Label1: TLabel;
  • Label2: TLabel;
  • eCle: TEdit;
  • bCrypter: TBitBtn;
  • bFermer: TBitBtn;
  • eResultat: TEdit;
  • Label3: TLabel;
  • bDecrypter: TBitBtn;
  • procedure eCleChange(Sender: TObject);
  • procedure eMessageChange(Sender: TObject);
  • procedure bCrypterClick(Sender: TObject);
  • procedure bDecrypterClick(Sender: TObject);
  • private
  • { Déclarations privées }
  • public
  • { Déclarations publiques }
  • end;
  • var
  • Form1: TForm1;
  • implementation
  • {$R *.dfm}
  • //Quand on fait un changement dans eCle
  • procedure TForm1.eCleChange(Sender: TObject);
  • begin
  • eResultat.Text:=''; //on efface le résultat
  • end;
  • //Quand on fait un changement dans eMessage
  • procedure TForm1.eMessageChange(Sender: TObject);
  • var verif : string;
  • begin
  • eResultat.Text:=''; //on efface le résultat
  • end;
  • //Quand on clique sur le bouton 'crypter'
  • procedure TForm1.bCrypterClick(Sender: TObject);
  • var cle , chaineBloc, chaineBlocResultat : string[8];
  • message, chaineFinale, varVerifMessage, varVerifCle : string;
  • i, j, nbBloc, longeurCourteChaine : integer;
  • begin
  • //On vérifie tout d'abord si la clé et le message sont corrects
  • varVerifCle:=verifCle(eCle.text);
  • varVerifMessage:=verifMessage(eMessage.Text);
  • if((varVerifCle<>'ok') or (varVerifMessage<>'ok') or (eCle.text='') or (eMessage.Text='')) then
  • begin
  • messagedlg('Le message doit contenir des caractères compris entre A et Z ainsi que l''espace.La clé doit contenir les chiffres de 1 à 8', mtWarning, [mbOk], 0);
  • end
  • else begin
  • message := eMessage.Text;
  • message := mettreEnMajuscule(message);
  • eMessage.text:=message;
  • cle := eCle.Text;
  • chaineFinale:='';
  • chaineBlocResultat:='00000000';
  • //On remplace tous les espaces par des 0
  • for i:=1 to length(message) do
  • begin
  • if (message[i]=' ') then
  • message[i]:='0';
  • end;
  • if((length(message))mod 8<>0) then
  • nbBloc:=trunc(length(message)/8)+1 //On regarde combien on a de bloc de 8char
  • else
  • nbBloc:=trunc(length(message)/8); //Si la longueur du message est multiple de 8
  • //On parcourt les blocs un par un
  • for i:=1 to nbBloc do
  • begin
  • chaineBloc:=copy(message,(i*8-7),8);
  • //Si on a la derniere chaine avec moins de 8 char, on rajoute des '0' à la fin
  • if (length(chaineBloc)<8) then
  • begin
  • longeurCourteChaine:=8-length(chaineBloc);
  • for j:=1 to longeurCourteChaine do
  • chaineBloc:=chaineBloc+'0';
  • end;
  • //On remplace les caractère par rapport à la clé
  • for j:=1 to 8 do
  • begin
  • chaineBlocResultat[j]:=chaineBloc[strtoint(cle[j])];
  • end;
  • chaineFinale:=chaineFinale+chaineBlocResultat; //On affect au résultat
  • end;
  • eResultat.Text:=chaineFinale; //Affichage du résultat
  • end;
  • end;
  • procedure TForm1.bDecrypterClick(Sender: TObject);
  • var cle , chaineBloc, chaineBlocResultat : string[8];
  • message, chaineFinale, varVerifMessage, varVerifCle : string;
  • i, j, nbBloc : integer;
  • begin
  • //On vérifie tout d'abord si la clé et le message sont corrects
  • varVerifCle:=verifCle(eCle.text);
  • varVerifMessage:=verifMessage(eMessage.Text);
  • if((varVerifCle<>'ok') or (varVerifMessage<>'ok') or (eCle.text='') or (eMessage.Text='')) then
  • begin
  • messagedlg('Le message doit contenir des caractères compris entre A et Z ainsi que l''espace.La clé doit contenir les chiffres de 1 à 8', mtWarning, [mbOk], 0);
  • end
  • else begin
  • message := eMessage.Text;
  • message := mettreEnMajuscule(message);
  • eMessage.text:=message;
  • cle := eCle.Text;
  • chaineFinale:='';
  • chaineBlocResultat:='00000000';
  • //Si on a pas une longueur de message multiple de 8, c'est qu'on a une erreur
  • if((length(message))mod 8<>0) then
  • messagedlg('Le message à décrypter est erroné', mtWarning, [mbOk],0)
  • else begin
  • nbBloc:=trunc(length(message)/8); //Si la longueur du message est multiple de 8
  • //On parcourt les blocs un par un
  • for i:=1 to nbBloc do
  • begin
  • chaineBloc:=copy(message,(i*8-7),8);
  • //On remplace les caractère par rapport à la clé
  • for j:=1 to 8 do
  • begin
  • chaineBlocResultat[strtoint(cle[j])]:=chaineBloc[j];
  • end;
  • chaineFinale:=chaineFinale+chaineBlocResultat; //On affect au résultat
  • end;
  • //On remplace les 0 par des espaces :
  • for i:=1 to length(chaineFinale) do
  • begin
  • if(chaineFinale[i]='0') then
  • chaineFinale[i]:=' ';
  • end;
  • eResultat.Text:=chaineFinale; //Affichage du résultat
  • end;
  • end;
  • end;
  • end.
///////////////////////////////////////////////////////////
//  Fichier              : uTransposition.pas            //
//  Auteur               : Stéphane Haimet               //
//  Date de création     : 01/02/08                      //
//  Date de modification : 15/02/08                      //
///////////////////////////////////////////////////////////

unit uTransposition;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, Buttons, uFonctions;

type
  TForm1 = class(TForm)
    eMessage: TEdit;
    Label1: TLabel;
    Label2: TLabel;
    eCle: TEdit;
    bCrypter: TBitBtn;
    bFermer: TBitBtn;
    eResultat: TEdit;
    Label3: TLabel;
    bDecrypter: TBitBtn;
    procedure eCleChange(Sender: TObject);
    procedure eMessageChange(Sender: TObject);
    procedure bCrypterClick(Sender: TObject);
    procedure bDecrypterClick(Sender: TObject);
  private
    { Déclarations privées }
  public
    { Déclarations publiques }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

//Quand on fait un changement dans eCle
procedure TForm1.eCleChange(Sender: TObject);
begin
   eResultat.Text:='';  //on efface le résultat
end;


//Quand on fait un changement dans eMessage
procedure TForm1.eMessageChange(Sender: TObject);
var verif : string;
begin
   eResultat.Text:='';  //on efface le résultat
end;


//Quand on clique sur le bouton 'crypter'
procedure TForm1.bCrypterClick(Sender: TObject);
var cle , chaineBloc, chaineBlocResultat : string[8];
    message, chaineFinale, varVerifMessage, varVerifCle : string;
    i, j, nbBloc, longeurCourteChaine : integer;
begin
   //On vérifie tout d'abord si la clé et le message sont corrects
   varVerifCle:=verifCle(eCle.text);
   varVerifMessage:=verifMessage(eMessage.Text);
   if((varVerifCle<>'ok') or (varVerifMessage<>'ok') or (eCle.text='') or (eMessage.Text='')) then
   begin
      messagedlg('Le message doit contenir des caractères compris entre A et Z ainsi que l''espace.La clé doit contenir les chiffres de 1 à 8', mtWarning, [mbOk], 0);
   end
   else begin
      message := eMessage.Text;
      message := mettreEnMajuscule(message);
      eMessage.text:=message;
      cle := eCle.Text;
      chaineFinale:='';
      chaineBlocResultat:='00000000';
      //On remplace tous les espaces par des 0
      for i:=1 to length(message) do
      begin
         if (message[i]=' ') then
            message[i]:='0';
      end;

      if((length(message))mod 8<>0) then
         nbBloc:=trunc(length(message)/8)+1 //On regarde combien on a de bloc de 8char
      else
         nbBloc:=trunc(length(message)/8); //Si la longueur du message est multiple de 8
      
      //On parcourt les blocs un par un
      for i:=1 to nbBloc do
      begin
         chaineBloc:=copy(message,(i*8-7),8);
         //Si on a la derniere chaine avec moins de 8 char, on rajoute des '0' à la fin
         if (length(chaineBloc)<8) then
         begin
            longeurCourteChaine:=8-length(chaineBloc);
            for j:=1 to longeurCourteChaine do
               chaineBloc:=chaineBloc+'0';
         end;

         //On remplace les caractère par rapport à la clé
         for j:=1 to 8 do
         begin
            chaineBlocResultat[j]:=chaineBloc[strtoint(cle[j])];
         end;

         chaineFinale:=chaineFinale+chaineBlocResultat;  //On affect au résultat
         
      end;
      eResultat.Text:=chaineFinale; //Affichage du résultat
   end;
end;


procedure TForm1.bDecrypterClick(Sender: TObject);
var cle , chaineBloc, chaineBlocResultat : string[8];
    message, chaineFinale, varVerifMessage, varVerifCle : string;
    i, j, nbBloc : integer;
begin
   //On vérifie tout d'abord si la clé et le message sont corrects
   varVerifCle:=verifCle(eCle.text);
   varVerifMessage:=verifMessage(eMessage.Text);
   if((varVerifCle<>'ok') or (varVerifMessage<>'ok') or (eCle.text='') or (eMessage.Text='')) then
   begin
      messagedlg('Le message doit contenir des caractères compris entre A et Z ainsi que l''espace.La clé doit contenir les chiffres de 1 à 8', mtWarning, [mbOk], 0);
   end
   else begin
      message := eMessage.Text;
      message := mettreEnMajuscule(message);
      eMessage.text:=message;
      cle := eCle.Text;
      chaineFinale:='';
      chaineBlocResultat:='00000000';

      //Si on a pas une longueur de message multiple de 8, c'est qu'on a une erreur
      if((length(message))mod 8<>0) then
         messagedlg('Le message à décrypter est erroné', mtWarning, [mbOk],0)
      else begin
         nbBloc:=trunc(length(message)/8); //Si la longueur du message est multiple de 8

         //On parcourt les blocs un par un
         for i:=1 to nbBloc do
         begin
            chaineBloc:=copy(message,(i*8-7),8);

            //On remplace les caractère par rapport à la clé
            for j:=1 to 8 do
            begin
               chaineBlocResultat[strtoint(cle[j])]:=chaineBloc[j];
            end;

            chaineFinale:=chaineFinale+chaineBlocResultat;  //On affect au résultat
         
         end;
         //On remplace les 0 par des espaces :
         for i:=1 to length(chaineFinale) do
         begin
            if(chaineFinale[i]='0') then
               chaineFinale[i]:=' ';
         end;
         eResultat.Text:=chaineFinale; //Affichage du résultat
      end;
   end;
end;

end.

 Conclusion

Enjoy

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !
  •   Programme 02 OK
    • Transposition.~dprTélécharger ce fichier [Réservé aux membres club]211 octets
    • Transposition.cfgTélécharger ce fichier [Réservé aux membres club]Voir ce fichier386 octets
    • Transposition.dofTélécharger ce fichier [Réservé aux membres club]Voir ce fichier1 097 octets
    • Transposition.dprTélécharger ce fichier [Réservé aux membres club]Voir ce fichier246 octets
    • Transposition.resTélécharger ce fichier [Réservé aux membres club]876 octets
    • uFonctions.~pasTélécharger ce fichier [Réservé aux membres club]2 530 octets
    • uFonctions.dcuTélécharger ce fichier [Réservé aux membres club]1 971 octets
    • uFonctions.pasTélécharger ce fichier [Réservé aux membres club]Voir ce fichier2 530 octets
    • uTransposition.~ddpTélécharger ce fichier [Réservé aux membres club]51 octets
    • uTransposition.~dfmTélécharger ce fichier [Réservé aux membres club]1 735 octets
    • uTransposition.~pasTélécharger ce fichier [Réservé aux membres club]5 610 octets
    • uTransposition.dcuTélécharger ce fichier [Réservé aux membres club]7 689 octets
    • uTransposition.ddpTélécharger ce fichier [Réservé aux membres club]51 octets
    • uTransposition.dfmTélécharger ce fichier [Réservé aux membres club]1 735 octets
    • uTransposition.pasTélécharger ce fichier [Réservé aux membres club]Voir ce fichier5 539 octets

Télécharger le zip


 Historique

25 novembre 2008 16:39:59 :
EDIT du 25/11/08 : Correction d'une erreur dans la description.

 Sources du même auteur

Source avec Zip Source avec une capture SIMULATION DE PLUSIEURS TIRAGES DU JEU DE JOKER (LOTTO)
Source avec Zip Source avec une capture CRYPTAGE : MÉTHODE DE SUBSTITUTION
Source avec Zip Source avec une capture MÉTHODE DE GAUSS ET DE CRAMER : RÉSOLUTION DE 10 ÉQUATIONS À...
Source avec Zip Source avec une capture MÉTHODE DICHOTOMIQUE : CALCUL DE RACINE CUBIQUE
Source avec Zip Source avec une capture MÉTHODE DE NEWTON : CALCUL D'UNE RACINE CARRÉE

 Sources de la même categorie

Source avec Zip Source avec une capture MANIPULATION TRÉS RAPIDE DE TRÉS GRANDES NOMBRES ENTIERS + F... par kamel78
Source avec Zip CONVERSION OF (HEX BIN OCT) TO EACH OTHER par MSBMW
Source avec Zip Source avec une capture RESOLUTION EQUATIONS DEGRE "N" + CALCULETTE SCIENTIFIQUE par pseudo3
Source avec Zip Source avec une capture DEUX BIBLIOTHÈQUES POUR CALCULER AVEC DES ENTIERS TRÈS GRAND... par Rekin85
Source avec Zip Source avec une capture MOTEUR PHYSIQUE 2D CHIPMUNK.. EN DELPHI! par Bacterius

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture GOLDEN PASSWORDS - STOCKEZ VOS MOTS DE PASSE ! par Bacterius
Source avec Zip Source avec une capture LEA EN MODE CHIFFREMENT (SEA) par Bacterius
Source avec Zip Source avec une capture CRYPTAGE : MÉTHODE DE SUBSTITUTION par bad_dark_spirit
Source avec Zip Source avec une capture MÉTHODE DE GAUSS ET DE CRAMER : RÉSOLUTION DE 10 ÉQUATIONS À... par bad_dark_spirit
Source avec Zip Source avec une capture MÉTHODE DICHOTOMIQUE : CALCUL DE RACINE CUBIQUE par bad_dark_spirit

Commentaires et avis

Commentaire de Bacterius le 23/08/2009 19:00:50

Eh ben ... le cryptage est pas terrible. Il y a trop de clefs faibles, voici une liste :

12345678 => ne change rien
13245678 => inverse seulement 2 caractères
et toutes les clefs qui comportent 3 chiffres consécutifs l'un après l'autre (123, 678, 345, ...).

Bref, il doit rester quatre ou cinq clefs valables, qu'il suffit de tester ... En plus l'algo répète la clef ... ouch.
Côté sécurité, ça marchait peut-être du temps de César mais là on sait faire mieux :)

(Je ne critique pas le code, mais uniquement le principe de l'algorithme)

Cordialement, Bacterius !

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Cryptage/Décryptage [ par cycy07 ] Bonjour, je dois pouvoir cr&#233;er une application selon la m&#233;thode de substitution (C&#233;sar) , il s'agit donc de pouvoir entrer un message & Cryptage en 27 caractères, méthode de substitution [ par cycy07 ] Bonsoir, est il possible d'utiliser la&nbsp;m&#233;thode de substitution pour une chaine de caract&#232;re utilisant les 26 lettres de l'alphabet+le b Messages d'erreur avec RaveReport [ par michelborland ] Bonjour,Quand je lance Rave report (depuis l'&#233;x&#233;cutable)je re&#231;ois un message d'&#233;rreur (No datalink has been loaded) Remarques : 1- ADO Message [ par helmis ] Comment Transformer Les messages D'erreur automatique d'ADO en des Messages programmer par le developpeur tout en suprimmant ceux de ADO. par exemple Les messages d"erreur [ par Zoubir ] Bonjour,Je demande est ce que c'est possible de personnaliser les messages d'erreur qui sont gérés automatiquement par Delphi telsque les messages d'e messages d'alerte de securite activeX a repetition?? [ par pasc ] Bonjour Je possède un pc fujitsu siemens xpertwindows ME I.E 6.2 (Netscap 6.2 et c plug in depuis peu)comment ne plus avoir c fenêtres d'alerte de su TNMPOP3 composant [ par Steph ] j'ai essayé d'utiliser le composant TNMPOP3 (FastNet) pour afficher le nombre de messages reçus (non lus ?) dans ma boite aux lettres Outlook.Pour cel Exécution d'une méthode incluse dans un package PL/SQL [ par DeadSoul ] Bonjour,Voici mon problème :Je désire exécuter une méthode PL/SQL incluse dans un package OracleJe connais l'existence de la classe TStoredProcedure, Messages windows [ par Gysmo ] Salut, Je n'arrive pas a faire d'operation logic sur les messages de windows de cette maniere:procedure TForm1.FormCreate(Sender: TObject);begin App Affichage écran de demarrage [ par lirva ] Bonjour,J'ai suivi la méthode de l'aide pour afficher une Form pendant 3 secondes au démarrage de mon appli :&lt;&lt;procedure TForm1.FormActivate(Sen


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
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,764 sec (3)

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