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.
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.