IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

Cryptage XOR en C


Sujet :

C

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2014
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2014
    Messages : 7
    Points : 10
    Points
    10
    Par défaut Cryptage XOR en C
    Bonjour,

    j'essaie depuis quelque temps de créer un petit programme de cryptage XOR (ou exclusif), avec la conception suivante :
    On a un fichier qui contient du texte quand veux crypter avec un algorithme de cryptage XOR à l'aide d'une clé numérique contenue dans un 2ème fichier. Le programme doit créer un 3ème fichier qui est le fichier crypté.

    J'ai crée beaucoup de versions de ce programme avec des résultats plus ou moins mitigés, mais la version la plus aboutie est ci-jointe avec ce post.
    Le code se compile sans problème mais pour une raison obscure le programme n'arrive pas à lire correctement la clé à partir du fichier qui la contient. Et svp avant de faire la compilation le fichier qu'on veux crypter et le fichier clé doivent déjà être créés au préalable.

    Merci de me répondre dans les plus brefs délais et n'oubliez pas que c'est mon premier post dans ce forum !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    void CryptageFichiersOuverts(FILE *pfIn, FILE *pfOut, int* clef)
    {
    	int carac;
    	clef = malloc (8 * sizeof(int));
    	while((carac = fgetc(pfIn)) != EOF)
    	{
    		int i;
    		for (i=0;i<8;i++)
    		{
    			int xored = carac ^ clef[i];
    			fputc(xored, pfOut);
    		}
    	}
    }
     
    void Cryptage(const char *nomFichSrc, const char *nomFichDest, int* clef)
    {
    	FILE *pfIn;
    	pfIn = fopen(nomFichSrc, "r");
    	if(pfIn == NULL)
    	{
    		puts("Echec d'ouverture du fichier source.");
    	}
    	else
    	{
    		FILE *pfOut =NULL;
    		pfOut = fopen(nomFichDest, "w");
    		if(pfOut == NULL)
    		{
    			puts("Echec d'ouverture du fichier destination.");
    		}
    		else
    		{
    			CryptageFichiersOuverts(pfIn, pfOut, clef);
    			fclose(pfOut);
    		}
     
    		fclose(pfIn);
    	}
     
    }
     
    void DemandeEtCrypte()
    {
    	char nomFich[300] = "";
    	char *pRetour = NULL;
    	int clef [8];
     
    	printf("Nom du fichier a crypter : \n");
    	fflush(stdout); // Nécessaire si une ligne ne se termine pas par \n - fflush(stdout) : fonction qui vide le tampon de sortie.
     
    	/* On lit le nom du fichier, 
    	   puis on vérifie qu'il rentre en entier dans la zone de 300 caractères.
    	   S'il rentre, le \n sera dedans, et il faudra le supprimer.
    	   Si ça ne rentre pas, le \n ne sera pas dedans, et on dira Erreur. */
     
           fgets (nomFich, 300, stdin);
    	pRetour = strchr(nomFich, '\n');
    	if(pRetour == NULL)
    	{
    		// Le \n final n'est pas dans le nom de fichier.
    		puts("Nom de fichier trop grand.\n");
    	}
    	else
    	{
    		// Le \n est présent : OK, on tronque la chaîne ici.
    		*pRetour = '\0';
    		FILE *pfclef;
    		pfclef = fopen("clef.txt", "r");
    		if (pfclef != NULL)
    		{
    			/*int j;
    			for (j=0;j<8;j++)
    			{	
    				scanf ("%d", &clef[j]);
    			}*/
    			fscanf (pfclef, "%s" , clef);
    			fclose (pfclef);
    		}
    		 else
    		{
    		 printf ("Erreur d'ouverture du fichier\n");
    		}
    		// On lit la clef.
     
    		/* On lance le cryptage du fichier, et on met le résultat dans "fichier_crypte.txt".
    		   Si on veut, on peut demander le nom du fichier destination à la place... */
    		Cryptage(nomFich, "crypte.txt", clef);	
    		printf ("fichier crypte\n");
    	}
    }
     
    int main(int argc, char *argv[]) {
    	DemandeEtCrypte();
    	return 0; 
    }
    Fichiers attachés Fichiers attachés

  2. #2
    En attente de confirmation mail

    Profil pro
    Inscrit en
    Septembre 2013
    Messages
    639
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 639
    Points : 2 347
    Points
    2 347
    Par défaut
    Je vois une incohérence. clef est déclaré tableau d'entiers... donc pourquoi scanf ("%s", clef) ?

  3. #3
    Expert éminent sénior
    Avatar de Kannagi
    Homme Profil pro
    cyber-paléontologue
    Inscrit en
    Mai 2010
    Messages
    3 214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cyber-paléontologue

    Informations forums :
    Inscription : Mai 2010
    Messages : 3 214
    Points : 10 140
    Points
    10 140
    Par défaut
    Je me pose juste la question pourquoi tu ne fais tout simplement pas un xor directement pendant la lecture/ecriture , en gros tu lis , tu applique le XOR et tu écris ensuite (sur le même fichier), il existe "r+" pour pouvoir lire et écrire sur le même fichier .

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2014
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2014
    Messages : 7
    Points : 10
    Points
    10
    Par défaut
    Bonjour,

    merci de vos vaillants efforts, mais j'ai un peu amélioré le code en introduisant la fonction "atoi" pour faciliter la lecture de la clef numérique. J'ai joint ci-dessous ma dernière version du code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    void CryptageFichiersOuverts(FILE *pfIn, FILE *pfOut, int clef)
    {
    	int carac;
    	while((carac = fgetc(pfIn)) != EOF)
    	{
    		int xored = carac ^ clef;
    		fputc(xored, pfOut);
    	}
     
    }
     
    void Cryptage(const char *nomFichSrc, const char *nomFichDest, int clef)
    {
    	FILE *pfIn = fopen(nomFichSrc, "r");
    	if(pfIn == NULL)
    	{
    		puts("Echec d'ouverture du fichier source.");
    	}
    	else
    	{
    		FILE *pfOut =NULL;
    		pfOut= fopen(nomFichDest, "w");
    		if(pfOut == NULL)
    		{
    			puts("Echec d'ouverture du fichier destination.");
    		}
    		else
    		{
    			CryptageFichiersOuverts(pfIn, pfOut, clef);
    			fclose(pfOut);
    		}
     
    		fclose(pfIn);
    	}
     
    }
     
    void DemandeEtCrypte()
    {
    	char nomFich[300] = "";
    	char *pRetour = NULL;
    	int clef;
     
    	printf("Nom du fichier a crypter : \n");
    	fflush(stdout); // Nécessaire si une ligne ne se termine pas par \n - fflush(stdout) : fonction qui vide le tampon de sortie.
     
    	/* On lit le nom du fichier, 
    	   puis on vérifie qu'il rentre en entier dans la zone de 300 caractères.
    	   S'il rentre, le \n sera dedans, et il faudra le supprimer.
    	   Si ça ne rentre pas, le \n ne sera pas dedans, et on dira Erreur. */
     
    	fgets(nomFich, 300, stdin);
    	pRetour = strchr(nomFich, '\n');
    	if(pRetour == NULL)
    	{
    		// Le \n final n'est pas dans le nom de fichier.
    		puts("Nom de fichier trop grand.\n");
    	}
    	else
    	{
    		// Le \n est présent : OK, on tronque la chaîne ici.
    		*pRetour = '\0';
     
    		FILE *pfclef;
    		pfclef = fopen("clef.txt", "r");
    		if (pfclef != NULL){
    			char nomClef[8]="";
     
    			fgets (nomClef,8,pfclef);
    			clef=atoi(nomClef);
    			fclose (pfclef);
    		}
    		 else{
    		 	printf ("Erreur d'ouverture du fichier\n");
    		}
    		Cryptage(nomFich, "crypte.txt", clef);
    		printf ("fichier crypté\n");	
    		}	
    }
     
    int main(int argc, char *argv[]) {
    	DemandeEtCrypte();
    	return 0; 
    }
    A +.

  5. #5
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Il faudrait savoir ce que tu manipules. Tu ouvres tes fichiers en mode texte, mais la sortie d'un cryptage XOR ordinaire n'est pas du texte, mais un tableau d'octets (peut contenir des caractères nuls, des caractères non-imprimables, et des séquences d'octets interdites dans l'encodage utilisé). C'est pourquoi généralement, quand on bosse en XOR, on bosse sur des fichiers binaires et non texte.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. cryptage xor avec clé
    Par deny dans le forum Sécurité
    Réponses: 0
    Dernier message: 29/06/2008, 08h54
  2. Cryptage / decryptage xor
    Par deny dans le forum Débuter
    Réponses: 2
    Dernier message: 08/06/2008, 11h52
  3. Probéme systeme de cryptage XOR
    Par raphy75 dans le forum Réseau
    Réponses: 38
    Dernier message: 11/07/2007, 22h30
  4. Cryptage XOR + clé variable
    Par jusi dans le forum Delphi
    Réponses: 9
    Dernier message: 26/02/2007, 14h49
  5. [delphi 7 perso] Cryptage XOR et assembleur
    Par Loran dans le forum Langage
    Réponses: 5
    Dernier message: 18/08/2005, 10h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo