[vc++] cryptage simple vigenère (commenté)

Description

Ce projet pour Visual C++ 6.0 est très simple,mais je le met quand même, on sait jamais, si ça peut en interesser un autre ...
La technique est celle de Vigenère, donc elle est elle aussi très simple, mais le système d'extension est lui plus compliqué ;) c'est pour simplifier la tâche...
Enfin c'est un peu le bordel...Si quelqu'un pense que j'ai fait n'importe quoi, je me ferait un plaisir d'écouter ses remarques :)

sylvainpasutto@yahoo.fr

Source / Exemple :


/*******************************************

  • Schema du cryptage Vigenère: *
  • *
  • chaine initiale...... *
  • + mot_de_passemot_de... *
  • =---------------------- *
  • texte crypté......... *
  • Gerald*
                                                                                      • /
#include <stdio.h> // printf(), fprintf()... #include <conio.h> // getch() #include <string.h> // strcpy(), strcat() #include <stdlib.h> void main(int argc,char *argv[]) { FILE *filename,*cryptedfile; // les pointeurs vers les fichiers char password[30]; // le mot de passe char filetemp[30]; // le nom du fichier unsigned int n=0; // le caractère lu unsigned int nb=0; // la position dans la chaîne du // mot de passe unsigned int len=0; // la longueur du mot de passe unsigned int taille=0; // la longueur de l'argument(nom du // fichier à crypter) char tmp=0; // la variable nulle if (argc != 2) { // Si l'utilisateur n'a pas mis les bons parametres, // on lui indique la syntaxe printf("\a\nusage : BSCryptDos infile\n"); // on attend la saisie de l'utilisateur getch(); } else { for(int gg=0;gg<argc;gg++) { // affichage de tout les paramètres printf("%d:%s\n",gg,argv[gg]); } printf("password:"); // on demande à l'utilisateur gets(password); // son mot de passe len = strlen(password); // puis on calcul sa taille taille = strlen(argv[1]);// ainsi que celle de l'argument strcpy(filetemp,argv[1]);// puis on copie l'argument dans // la chaîne prévue à cet effet do { // on recherche dans taille--; // la chaîne "filetemp" } // le caractere 'point' while (filetemp[taille] != '.'); // puis on le remplace filetemp[taille] = '\0'; // par le caractere fin de chaîne // on ouvre le fichier à crypter: si fopen() renvoie 'NULL', // c'est que ça a planté if ((filename = fopen(argv[1],"rb+")) != NULL) { // on remplace l'estension par l'estension '.bsc' strcat(filetemp,".bsc"); // on crée le fichier qui sera crypté if ((cryptedfile = fopen(filetemp,"wb+")) != NULL) { for (int i=0;;i++) { nb++; // à chaque tour, on passe du // premier caractere du mot de // passe au second, et ainsi // de suite; if (nb>len) nb=0; // si nb est plus grand que len, // c'est qu'on est à la fin du // mot de passe, donc on revient // au début tmp += password[nb]; // on rajoute 1 au password pour // éviter les caracteres 'null' // (voir message de Croqmort) n = fgetc(filename); // on lit un caractere dans le // fichier non crypté if (n == EOF) break; // on vérifie si on est pas à la // du fichier non crypté // enfin, on écrit sous forme de caractere la valeur // ASCII du caractere lu ajoutée à la position // correspondante dans le mot de passe fprintf(cryptedfile,"%c",n + tmp); } } // on informe l' utilisateur que c'est fini ;) printf("\ncryptage termine"); } } }

Conclusion :


Remarque: la source du décrypteur est séparée de celle du crypteur, pour plus de clarté.Elle se trouve dans le Zip.

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.

Du même auteur (cs_Gerald)