π
<-

Outil pour la methode de chiffrement XOR

Discussions scientifiques et scolaires

Outil pour la methode de chiffrement XOR

Unread postby Ti64CLi++ » 17 Nov 2017, 21:34

Depuis quelque temps, je me suis remis aux epreuves de Newbiecontest, un site de challenge.
Hier je suis tombe sur une epreuve faisant intervenir une methode de cryptage appellee XOR.

Pour ceux qui ne connaissent pas, je vous laisse le soin de taper dans la barre de recherche de votre moteur de recherche prefere :D (un peu de repetition mais ca va :p)

Je me suis donc lance dans la creation de 3 outils pour m'aider dans cette taches:
  • Le premier pour retrouver la clef de chiffrement utilise a partir du texte crypte en hexadecimal, et d'une partie du (ou de tout le) texte decrypte (celui ci n'est pas entierement de moi)
  • Le deuxieme pour crypter un texte a l'aide d'une clef specifie (je vous conseille de ne pas mettre d'espace dans votre texte a crypter). Affiche le texte crypte en hexadecimal
  • Et le troisieme pour decrypter un texte crypter a l'aide de sa valeur l'hexadecimal, a l'aide d'une clef donne. Il affiche le texte en hexadecimal et en ASCII

Voila amusez vous bien, et en esperant que ca serve.

P.S.:
Tout ces outils sont codes en C++, et compiles pour linux.
You do not have the required permissions to view the files attached to this post.
Image
User avatar
Ti64CLi++Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 32.5%
 
Posts: 3446
Images: 75
Joined: 04 Jul 2014, 14:40
Location: Clermont-Ferrand 63
Gender: Male
Calculator(s):
MyCalcs profile
Class: ENS Rennes
GitHub: Ti64CLi

Re: Outil pour la methode de chiffrement XOR

Unread postby Lionel Debroux » 17 Nov 2017, 21:36

C'est bien de chercher à apprendre par ce genre de challenges (j'avais fait une cinquantaine de problèmes du Project Euler il y a maintenant 6 ans), et de publier tes outils.

Je voudrais juste expliciter le fait que le chiffrement XOR n'est absolument pas à utiliser pour autre chose que des exercices d'apprentissage :)
Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
User avatar
Lionel DebrouxSuper Modo
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 11.3%
 
Posts: 6865
Joined: 23 Dec 2009, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Class: -
GitHub: debrouxl

Re: Outil pour la methode de chiffrement XOR

Unread postby Adriweb » 17 Nov 2017, 22:59

En théorie, pour un chiffrement, si la clé XOR est seule connue des 2 participants a leur conversation "chiffrée" avec ladite clé, il n'y a pas mieux comme protection.
Le mieux étant une clé XOR au moins aussi longue que le message :P

MyCalcs: Help the community's calculator documentations by filling out your calculators info!
MyCalcs: Aidez la communauté à documenter les calculatrices en donnant des infos sur vos calculatrices !
Inspired-Lua.org: All about TI-Nspire Lua programming (tutorials, wiki/docs...)
My calculator programs
Mes programmes pour calculatrices
User avatar
AdriwebAdmin
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 79.2%
 
Posts: 14778
Images: 1123
Joined: 01 Jun 2007, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Twitter: adriweb
GitHub: adriweb

Re: Outil pour la methode de chiffrement XOR

Unread postby Lionel Debroux » 17 Nov 2017, 23:05

Mouais, mais XOR mâche beaucoup moins les bits que les algorithmes de chiffrement bien faits, qui utilisent des clés beaucoup plus courtes. Avec des clés de taille usuelle, le XOR prête le flanc à l'analyse statistique du contenu.
Membre de la TI-Chess Team.
Co-mainteneur de GCC4TI (documentation en ligne de GCC4TI), TIEmu et TILP.
User avatar
Lionel DebrouxSuper Modo
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Level up: 11.3%
 
Posts: 6865
Joined: 23 Dec 2009, 00:00
Location: France
Gender: Male
Calculator(s):
MyCalcs profile
Class: -
GitHub: debrouxl

Re: Outil pour la methode de chiffrement XOR

Unread postby Ti64CLi++ » 17 Nov 2017, 23:12

Je suis en train de faire la meme chose pour Vigenere et Beaufort
Image
User avatar
Ti64CLi++Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 32.5%
 
Posts: 3446
Images: 75
Joined: 04 Jul 2014, 14:40
Location: Clermont-Ferrand 63
Gender: Male
Calculator(s):
MyCalcs profile
Class: ENS Rennes
GitHub: Ti64CLi

Re: Outil pour la methode de chiffrement XOR

Unread postby Wistaro » 17 Nov 2017, 23:16

Tiens ça me rapelle mon dernier BE d'info..

On devait implanter en C le cryptage de Vigenere et trouver un moyen de cracker le code ne connaissant pas la clef..

Ça peut être très intéressant si tu t'intéresses au cryptage, c'est un bon exercice.
Sinon, on a aussi fait le cryptage de Hill, mais c'est un chouia plus complexe (ça fait intervenir des produits matriciels), mais tout aussi sympathique :)
Nouveau sur le site, ClaudeBot [spider] ? Avant de poster sur le chat et sur le forum, n'oublie pas de lire les règles. En cas de problème, tu peux m'envoyer un message, je réponds rapidement.

Liens utiles:
Image
Découvre mes programmes et mon site!
User avatar
WistaroSuper Modo
Niveau 15: CC (Chevalier des Calculatrices)
Niveau 15: CC (Chevalier des Calculatrices)
Level up: 88.4%
 
Posts: 3183
Images: 37
Joined: 25 Feb 2013, 16:21
Location: Toulouse
Gender: Male
Calculator(s):
MyCalcs profile
Class: Ingénieur en électronique
YouTube: Wistaro
Twitter: Wistaro
GitHub: Wistaro

Re: Outil pour la methode de chiffrement XOR

Unread postby Ti64CLi++ » 17 Nov 2017, 23:17

Vigenere, c'est fait, la je m'attaque a Beaufort, ca devrait pas etre plus complique.
Juste un moins et l'ordre
Image
User avatar
Ti64CLi++Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 32.5%
 
Posts: 3446
Images: 75
Joined: 04 Jul 2014, 14:40
Location: Clermont-Ferrand 63
Gender: Male
Calculator(s):
MyCalcs profile
Class: ENS Rennes
GitHub: Ti64CLi

Re: Outil pour la methode de chiffrement XOR

Unread postby Wistaro » 17 Nov 2017, 23:19

Ti64CLi++ wrote:Vigenere, c'est fait, la je m'attaque a Beaufort, ca devrait pas etre plus complique.
Juste un moins et l'ordre


Tu as le code de Vigenere ? Je suis curieux de savoir comment tu as procedé.. :)

Sinon ouais Beaufort c'est pas très compliqué non plus.
Nouveau sur le site, ClaudeBot [spider] ? Avant de poster sur le chat et sur le forum, n'oublie pas de lire les règles. En cas de problème, tu peux m'envoyer un message, je réponds rapidement.

Liens utiles:
Image
Découvre mes programmes et mon site!
User avatar
WistaroSuper Modo
Niveau 15: CC (Chevalier des Calculatrices)
Niveau 15: CC (Chevalier des Calculatrices)
Level up: 88.4%
 
Posts: 3183
Images: 37
Joined: 25 Feb 2013, 16:21
Location: Toulouse
Gender: Male
Calculator(s):
MyCalcs profile
Class: Ingénieur en électronique
YouTube: Wistaro
Twitter: Wistaro
GitHub: Wistaro

Re: Outil pour la methode de chiffrement XOR

Unread postby Ti64CLi++ » 17 Nov 2017, 23:30

Pour Vigenere (ca donne la clef a partir du texte crypte et d'une partie ou de tout le texte en clair):
Show/Hide spoilerAfficher/Masquer le spoiler
Code: Select all
#include <iostream>
#include <string>
#include <cmath>

using namespace std;

int main(int argc, char **argv)
{
   string texteChiffre;
   string texteClaire;
   int longueurTexteChiffre;
   int longueurTexteClaire;
   int difference;
   char lettre1, lettre2,clef;

   cout << "Entrez le texte chiffre en majuscule sans caractere accentue : ";
   getline(cin,texteChiffre);

   cout << "Entrez le texte clair en majuscule sans caractere accentue : ";
   getline(cin,texteClaire);
   
   
   longueurTexteChiffre = texteChiffre.length();
   longueurTexteClaire = texteClaire.length();

   if(longueurTexteClaire > longueurTexteChiffre)
   {
      cout << "La longueur du texte clair doit etre inferieur ou egale a la longueur du texte chiffre" << endl;
      return 0;
   }

   cout << "Resultat de la clef" << endl;
   
   for(int i=0; i < longueurTexteClaire; i++)
   {
      lettre1 = texteChiffre.at(i) - 'A';
      lettre2 = texteClaire.at(i) - 'A';

      difference = (lettre1 - lettre2);

      if(difference < 0)
      {
         clef = char(65+(26 - abs(difference)));
      }
      else
      {
         clef = char(difference + 65);
      }
      cout << clef;
   }

   cout << endl;

   return 0;
}


Ca peut donner la clef plusieurs fois a la suite, si la clef est plus petite que le texte clair
Image
User avatar
Ti64CLi++Modo
Niveau 16: CC2 (Commandeur des Calculatrices)
Niveau 16: CC2 (Commandeur des Calculatrices)
Level up: 32.5%
 
Posts: 3446
Images: 75
Joined: 04 Jul 2014, 14:40
Location: Clermont-Ferrand 63
Gender: Male
Calculator(s):
MyCalcs profile
Class: ENS Rennes
GitHub: Ti64CLi

Re: Outil pour la methode de chiffrement XOR

Unread postby Wistaro » 17 Nov 2017, 23:40

Ti64CLi++ wrote:Pour Vigenere (ca donne la clef a partir du texte crypte et d'une partie ou de tout le texte en clair):
Show/Hide spoilerAfficher/Masquer le spoiler
Code: Select all
#include <iostream>
#include <string>
#include <cmath>

using namespace std;

int main(int argc, char **argv)
{
   string texteChiffre;
   string texteClaire;
   int longueurTexteChiffre;
   int longueurTexteClaire;
   int difference;
   char lettre1, lettre2,clef;

   cout << "Entrez le texte chiffre en majuscule sans caractere accentue : ";
   getline(cin,texteChiffre);

   cout << "Entrez le texte clair en majuscule sans caractere accentue : ";
   getline(cin,texteClaire);
   
   
   longueurTexteChiffre = texteChiffre.length();
   longueurTexteClaire = texteClaire.length();

   if(longueurTexteClaire > longueurTexteChiffre)
   {
      cout << "La longueur du texte clair doit etre inferieur ou egale a la longueur du texte chiffre" << endl;
      return 0;
   }

   cout << "Resultat de la clef" << endl;
   
   for(int i=0; i < longueurTexteClaire; i++)
   {
      lettre1 = texteChiffre.at(i) - 'A';
      lettre2 = texteClaire.at(i) - 'A';

      difference = (lettre1 - lettre2);

      if(difference < 0)
      {
         clef = char(65+(26 - abs(difference)));
      }
      else
      {
         clef = char(difference + 65);
      }
      cout << clef;
   }

   cout << endl;

   return 0;
}


Ca peut donner la clef plusieurs fois a la suite, si la clef est plus petite que le texte clair


Du coup c'est pas du cryptage de Vigenere ça, c'est pour trouver la clef -_-
Nouveau sur le site, ClaudeBot [spider] ? Avant de poster sur le chat et sur le forum, n'oublie pas de lire les règles. En cas de problème, tu peux m'envoyer un message, je réponds rapidement.

Liens utiles:
Image
Découvre mes programmes et mon site!
User avatar
WistaroSuper Modo
Niveau 15: CC (Chevalier des Calculatrices)
Niveau 15: CC (Chevalier des Calculatrices)
Level up: 88.4%
 
Posts: 3183
Images: 37
Joined: 25 Feb 2013, 16:21
Location: Toulouse
Gender: Male
Calculator(s):
MyCalcs profile
Class: Ingénieur en électronique
YouTube: Wistaro
Twitter: Wistaro
GitHub: Wistaro

Next

Return to Maths, physique, informatique et autre...

Who is online

Users browsing this forum: ClaudeBot [spider] and 6 guests

-
Search
-
Social TI-Planet
-
Featured topics
Grand Concours 2024-2025 - Programmation Python
Comparaisons des meilleurs prix pour acheter sa calculatrice !
"1 calculatrice pour tous", le programme solidaire de Texas Instruments. Reçois gratuitement et sans aucune obligation d'achat, 5 calculatrices couleur programmables en Python à donner aux élèves les plus nécessiteux de ton lycée. Tu peux recevoir au choix 5 TI-82 Advanced Edition Python ou bien 5 TI-83 Premium CE Edition Python.
Enseignant(e), reçois gratuitement 1 exemplaire de test de la TI-82 Advanced Edition Python. À demander d'ici le 31 décembre 2024.
Aidez la communauté à documenter les révisions matérielles en listant vos calculatrices graphiques !
12345
-
Donations / Premium
For more contests, prizes, reviews, helping us pay the server and domains...
Donate
Discover the the advantages of a donor account !
JoinRejoignez the donors and/or premium!les donateurs et/ou premium !


Partner and ad
Notre partenaire Jarrety Calculatrices à acheter chez Calcuso
-
Stats.
1126 utilisateurs:
>1099 invités
>20 membres
>7 robots
Record simultané (sur 6 mois):
6892 utilisateurs (le 07/06/2017)
-
Other interesting websites
Texas Instruments Education
Global | France
 (English / Français)
Banque de programmes TI
ticalc.org
 (English)
La communauté TI-82
tout82.free.fr
 (Français)