Cryptage d'une chaine - Algo - Programmation
Marsh Posté le 23-11-2008 à 20:55:12
ReplyMarsh Posté le 24-11-2008 à 08:07:52
c'en est un
tu choisis un algo dans la liste (symétrique, ca sera plus simple), tu fais ce que tu peux pour le comprendre, et apres tu l'implémentes, sans copier/coller l'implémentation de référence.
parce que pour l'instant, ton algo de chiffrement, c'est ca :
chaine[i]=chaine[i]+5*9-2
ce qui veut dire que chaque caractère a son correspondant, systématiquement le même.
Marsh Posté le 24-11-2008 à 09:26:00
Fait du chiffre de playfair c'est normallement de ton niveau et c'est assez rapide. Puis si tu fait un projet sur le cryptage, faut quand meme avoir une partie theorique correcte sur chiffrement symetrique/asymetrique, cle publique cle privé, chiffrement ou hachage, etc...
Marsh Posté le 24-11-2008 à 09:36:09
Hamy a écrit : Je m'attendais à un pti coup d'pouce |
De quel genre?
Faut voir ce que tu veux "optimiser". Parce que là, on dirait un simple exercice de TP, pas un projet.
Petit détail : while(fin), c'est très curieux.
Marsh Posté le 24-11-2008 à 09:42:39
commence déjà par corriger la faille de buffer overflow.
Marsh Posté le 24-11-2008 à 09:48:45
jagstang a écrit : commence déjà par corriger la faille de buffer overflow. |
Boh, les profs s'en soucient à ce niveau?
Donne-lui peut-être un input qui va poser pb; je sens que ça pas passer au sinon.
Marsh Posté le 24-11-2008 à 11:36:15
ben une chaine plus longue que le buffer qu'il a prévu...
Marsh Posté le 24-11-2008 à 19:21:22
Oula oula
Citation : commence déjà par corriger la faille de buffer overflow. |
Citation : Donne-lui peut-être un input qui va poser pb; je sens que ça pas passer au sinon. |
pas trop compris !
Bon je sais que ce que j'ai fais est simplissime.
En résumé: je souhaiterai que chaque caractère codé possède sa propre clé (cryptage asymétrique je crois).
Le projet est pour mi-janvier 2009. J'ai un peu d'avance donc j'aimerai par la suite créer une légère interface de ce genre:
http://www.oussx.somee.com/images/cryptx.jpg
Marsh Posté le 24-11-2008 à 19:46:51
Pour la remarque du buffer overflow, jagstang a tout de même donné une explication limpide suite à ma remarque...
Pour le reste, beh, au boulot
Marsh Posté le 24-11-2008 à 23:43:32
Le cryptage n'est pas très efficace quand même là, avant de penser à une GUI pour égayer tout ça, je pense que ce serait plus intéressant (pour toi) d'étudier des algos plus performant.
Dans ton cas, une étude des fréquences d'apparition des lettres sur un texte assez long permet généralement de retrouver la correspondance entre le texte crypté et le texte original. Une fois qu'on a cette correspondance, on peut décrypter tout les messages qui passeraient par ton algo.
Marsh Posté le 25-11-2008 à 08:59:25
raté c'est symmetrique (sinon il te faudrait 2 clés)
Sinon ce que tu fais c'est de la substitution monoalphabétique
Marsh Posté le 25-11-2008 à 10:05:52
Son algo est pourri, s'il rend ça il va se faire rire au nez.
En DUT en premier semestre j'avais fait du cryptage en algo vigenere/playfair qui est deja un vrai algo et surtout momontre un poil de recherche.
Apres c'est sur que fait du cryptage plus evolué c'est pas forcement facile, mais les cryptage simple son abordable.
Marsh Posté le 25-11-2008 à 10:19:09
clair que c'est du crpytage primitif. Mais c'est un poil ludique pour se familiariser avec le C.
Vigenère est en effet du vrai cryptage. Car il est en effet absolument incassable (seul hic, la clé doit être aussi longue que le message. Ce qui rend le transport de la clé problématique...)
Marsh Posté le 25-11-2008 à 10:40:59
De tête, si la clef est plus petite que le message, on l'utilise "en boucle".
Mais bon ça reste imparfait, car ça ne fonction qu'avec des caractère alphabetique non accentués.
Marsh Posté le 25-11-2008 à 10:45:36
en l'utilisant en boucle il devient imparfait en effet. Pour les caractère accentués c'est faux. Libre à toi de choisir ton ensemble pour la chaine et la clé
Marsh Posté le 25-11-2008 à 14:11:16
Bon et bien au boulot, je vais m'inspirer des algo de type vigenere playfair etc...
Si j'ai bien compris les méthodes sont:
Les données de la chaine doivent changer de place,
Evidemment changer de valeur
Attribuer un clé
Marsh Posté le 23-11-2008 à 20:34:54
Bonjour à tous,
Dans le cadre d'un projet informatique en DUT, j'ai choisi: "Cryptage d'une chaine de caractère".
J'aimerai beaucoup améliorer mon programme. Mais comment?
Voici le code actuel:
(La fonction decryptage est futile)
Ceci est une méthode parmi tant d'autres.
Pourriez vous me dire comment je pourrais optimiser mon code?
Merci d'avance!