Aller au contenu

[Cryptage] XOR Fait maison


Karles
 Share

Recommended Posts

Bonjour tout le monde,

 

Je vais vous montrer un petit programme simple qui va permettre de crypter et de décrypter un fichier à l'aide de l’algorithme XOR.

Cet algorithme est très simple et léger, il offre une bonne protection sans plus, vous pouvez choisir la clé de cryptage que vous voulez.

 

Commencez par créer une solution DOS Win32 en C++ sous Visual Studio (2010 pour ma part), puis dans le fichier source main (principal) mettez ceci :

#include "stdafx.h"
#include <stdio.h>
#include <STDLIB.H>
#include <string.h>

/*------------------------------------------------------------------*/
/*------------------------------------------------------------------*/
/*------------------------------------------------------------------*/

int crypt (char *clefc,char pathc[255],char targetc[255]);/*fonction de cryptage*/
int decrypt (char *clefd,char pathd[255],char targetd[255]);/*decryptage*/
void bann();/*Montre comment utiliser le programme*/
void test(char *fnc,char *cl,char pathg[255],char target[255]);/*permet d'analyser l'entrée en ligne de commande*/
FILE *fichier; /*handle vers le fichier source*/                                                     
FILE *dest; /*handle vers le fichier destination*/

/*------------------------------------------------------------------*/
/*------------------------------------------------------------------*/
/*------------------------------------------------------------------*/

int main(int argc, char *argv[])
{
 /* Vérifie le nombre d'argument en ligne de commande et s'il est exact
    il les teste pour determiner l'action a faire*/
  if (argc==1 || argc==2) 
     bann();
  else 
     test(argv[1],argv[3],argv[2],argv[4]);
  return 0;
}

/*.................................................................*/
void bann()
 {
   puts("\n\t\t<------------------XorCrypt-------------------->");
   puts("\t\t<-------------------------------------------->\n");
   puts("Fonctionnement :");
   puts("xorcrypt -c nom_de_fichier clef Destination  : Crypte le ficher");
   puts("       -d nom_de_fichier clef Destination  : Decrypte le fichier");
   puts("Exemple  : xorcrypt -c texte.txt clef texte2.txt\n");
   system("pause");
 }
/*.................................................................*/
/* Test des valeurs entrées en argument de la ligne de commande */
 void test(char *fnc, char *cl, char pathg[255],char target[255])
  {
 if (strcmp(fnc,"-c")==0)
     crypt(cl,pathg,target);
 else if (strcmp(fnc,"-d")==0)
     decrypt(cl,pathg,target);
 else
     bann();
  }
/*.................................................................*/
/* Fonction de cryptage*/
int crypt (char *clefc,char pathc[255],char targetc[255])
{
int pd=0;/*initialisation du compteur de la clef*/
int c;
int i;
if (clefc!=NULL && pathc!=NULL && targetc!=NULL)/* Verification des arguments necessaires*/
   {
  if (fichier=fopen(pathc,"rb"))/* ouverture du fichier source en mode lecture binaire */ 
     {
    dest=fopen(targetc,"wb");/* ouverture du fichier destination en mode ecriture binaire */
    puts("Fichier ouvert\n Encryption en cours...");
    while((c=fgetc(fichier))!=EOF)/* En boucle jusqu'a la fin du fichier*/
      {
     c=~c;/*Réalise une inversion des bits  du caractere*/
     c^=clefc[pd];/* Effectue un XOR sur le caractere avec un caractere de le clef */
     fprintf(dest,"%c",c);/* ecrit le caractere dans le fichier */
    if (pd!=strlen(clefc))/*test de la clef */
       {pd+=1;} 
     else
       {pd=0;}
      }
    puts("Encryption effectuée");
    fclose(fichier);
    fclose(dest);
     }
  else 
     {
    puts("Impossible d'ouvrir le fichier");
     } 
   }
else
   puts("Argument manquant");
	return false;
}

/*.................................................................*/
/*fonction de decryptage*/
int decrypt (char *clefd,char pathd[255],char targetd[255])
{
int pd=0;
int c;
int i;
if (clefd!=NULL && pathd!=NULL && targetd!=NULL) /*Test des arguments necessaires */
   {
   if (fichier=fopen(pathd,"rb"))/* ouverture du fichier source en lecture binaire */
     {
    dest=fopen(targetd,"wb"); /* fichier destination en lecture binaire */ 
    puts("Fichier ouvert\n Decryptage en cours ...");
    while((c=fgetc(fichier))!=EOF)/* Boucle tant que le fichier n'a pas été entierement parcouru */
      {
     c^=clefd[pd]; /* applique un XOR sur un caractere avec un caractere de la clef */ 
     c=~c; /* Rotation des bits */
     fprintf(dest,"%c",c); /*ecriture dans le fichier destination */
    if (pd!=strlen(clefd)) /* Test de la clef */
       {pd+=1;} 
     else
       {pd=0;}
      }
    puts("Decryptage effectué");
    fclose(fichier);
    fclose(dest);
     }
  else 
     {
    puts("Impossible d'ouvrir le fichier");
     } 
   }
else
   puts("Argument manquant");
	return false;
   }

Vous enregistrez, vous compilez, vous récupérez l'exe et vous le mettez dans un dossier tout seul, renommez-le en xorcrypt.exe

 

I. Le Cryptage

Ensuite vous allez créer un .bat nommé Crypt.bat, dedans vous y mettez :

xorcrypt -c nocrypt.txt %CLEF% crypt.txt

Remplacez %CLEF% par un mot, un SHA1, un MD5, ce que vous vouez, sans espace. Et remplacez nocrypt.txt par le fichier source non crypté, et crypt.txt par le fichier destination crypté.

Fonctionne avec toute les extensions de fichier.

 

Mettez-le dans le même dossier que xorcrypt.exe, et mettez le fichier .txt(ou autre) source au même endroit que les 2 fichier précédents. Lancez Crypt.bat et votre fichier va se Crypter.

 

2. Le décryptage

Créer un .bat nommé Decrypt.bat, mettez-le dans le même dossier que les 2 autres fichiers (xorcrypt et Crypt), et remplissez-le comme ceci :

xorcrypt -d crypt.txt %CLEF% nocrypt.txt

Remplacez %CLEF% par la même clef qui a servi au cryptage de ce fichier. Et remplacez crypt.txt par le fichier source crypté, et nocrypt.txt par le fichier destination décrypté. Lancez Decrypt.bat et votre fichier va se décrypter.

 

Le tour est joué, vous pouvez désormais crypter un fichier et le décrypter très simplement, il ne reste plus qu'à implanter le décryptage dans un programme pour pouvoir crypter le contenu (pour un jeu par exemple) :)

 

Code fournit par http://codes-sources.commentcamarche.net et remanié par Karles.

 

Cordialement,

Karles

  • Upvote 3
Lien vers le commentaire
Partager sur d’autres sites

Tu peux proposer une amélioration si tu le souhaite, style l'utilisation libC pour le C. Et pourquoi pas faire aussi un code orienté C++ uniquement tu vois.

Ce code est assez polyvalent et simple, et pas très poussé ça c'est sur mais à mon avis les optimisations et modifications de lecture ne serviraient pas à grand chose honnêtement.

 

En revanche ce code est fonctionnel avec un programme C & C++ bien que son code n'ait pas grand chose du C++ :)

 

Si Azad veut déplacer en section C il peut, à moins que le code évolue :P

Lien vers le commentaire
Partager sur d’autres sites

Tu peux proposer une amélioration si tu le souhaite, style l'utilisation libC pour le C. Et pourquoi pas faire aussi un code orienté C++ uniquement tu vois.

Ce code est assez polyvalent et simple, et pas très poussé ça c'est sur mais à mon avis les optimisations et modifications de lecture ne serviraient pas à grand chose honnêtement.

 

En revanche ce code est fonctionnel avec un programme C & C++ bien que son code n'ait pas grand chose du C++ :)

 

Si Azad veut déplacer en section C il peut, à moins que le code évolue :P

Modifié par AlexMog
Lien vers le commentaire
Partager sur d’autres sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Invité
Répondre à ce sujet…

×   Vous avez collé du contenu avec mise en forme.   Supprimer la mise en forme

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Chargement
 Share

×
×
  • Créer...