Accueil > > > [VC++] CRYPTAGE SIMPLE VIGENÈRE (COMMENTÉ)
[VC++] CRYPTAGE SIMPLE VIGENÈRE (COMMENTÉ)
Information sur la source
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
- /*******************************************
- * 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");
- }
- }
-
- }
/*******************************************
* 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.
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui l'ont sagement suivi. Je profite de ce poste pour fai...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLETECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLE par ROMELARD Fabrice
Speakers: Julien Marechal, Gautier Confiant, Sébastien MEYER La session débute par le positionnement de la solution System Center par rapport aux concepts d'organisation ITIL. Le portail du catalogue de se...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : PLEINIèRE SECOND JOURTECHDAYS PARIS 2012 : PLEINIèRE SECOND JOUR par ROMELARD Fabrice
Après une première journée dédiée aux développeurs, cette seconde journée est dédiée au monde des entreprises et de ses applications. Ainsi, cette pleinière est dédiée à faire un 360 de l'évolution des applications Business aux demandes ac...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : RETOUR D'EXPéRIENCE SUR LA MISE EN PLACE D'UN CLOUD PRIVéTECHDAYS PARIS 2012 : RETOUR D'EXPéRIENCE SUR LA MISE EN PLACE D'UN CLOUD PRIVé par ROMELARD Fabrice
Speaker : Guillaume Rochette Cette session est dédiée à fournir le retour sur la mise en place d'un cloud privé (IaaS) par Osiatis pour son compte ou celui de ses clients. Ce projet s'est déroulé sur 4 mois et a permis de faire évoluer...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|