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 :

Lecture bloc par bloc d'un fichier pour opération de chiffrage


Sujet :

C++

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 10
    Points : 9
    Points
    9
    Par défaut Lecture bloc par bloc d'un fichier pour opération de chiffrage
    EDIT :

    Bon j'ai réétudier la question, construit un code plus léger etc..
    Mais le problème est toujours le même ..

    J'écris un module de chiffrage utilisant l'algorithme de rijndael, celui ci nécessite des bloc de 16 octet qu'il chiffre.

    Hors admettons que mon fichier pèse 205 octets ... il y a donc 12 bloc de 16 octets qui seront chiffré mais la ou il y a erreur .. c'est sur les derniers octets :
    12 * 16 = 192 octets
    205 - 192 = 13 octets ...

    Donc lors du dernier passage, on envoie 13 octets normaux et 3 octets X ... ce qui fausse le fichier crypté.

    Exemple :
    Ceci est le texte a chiffrer.
    En plus, normalement, il ne contient aucune fautes.
    Mais surtout, bien écrit.
    Deviens :
    Ceci est le texte a chiffrer.
    En plus, normalement, il ne contient aucune fautes.
    Mais surtout, bien écrit.
    Je remplace les espaces par des % :

    Ceci%est%le%texte%a%chiffrer.
    En%plus,%normalement,%il%ne%contient%aucune%fautes.
    Mais%surtout,%bien%écrit.%%%
    Donc le fichier de base et le fichier décrypté ne sont plus identique.
    Existe t-il une solution simple a cela ?

    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
     
    void FileModule::CryptFile(std::string filepath, std::string key)
    {
        std::ifstream inFile(filepath.c_str(), std::ios::binary);
        std::ofstream outFile("CryptTest.txt", std::ios::binary);
     
        inFile.seekg( 0 , std::ios_base::end );
        long sizeFile = inFile.tellg() ;
        inFile.seekg( 0,  std::ios_base::beg ) ;
     
        int cycle = ( sizeFile / 16 );
        int lastoctect = ( sizeFile % 16 );
     
        unsigned char ukey[] = "aaaaaaaabbbbbbbb";
     
        /*while ( !inFile.eof() )
        {
            unsigned char buffer[16];
     
            inFile.read((char*)buffer, sizeof(buffer));
     
            pAESMod->RijndaelCrypt(buffer, ukey, 0);
     
            outFile.write((const char*)buffer, sizeof(buffer));
        }*/
     
        for ( int i = 0; i < cycle ; i++ )
        {
            unsigned char buffer[16];
     
            inFile.read((char*)buffer, sizeof(buffer));
     
            pAESMod->RijndaelCrypt(buffer, ukey, 0);
     
            outFile.write((const char*)buffer, sizeof(buffer));
        }
     
        if ( lastoctect != 0 )
        {
            unsigned char mbuffer[lastoctect];
     
            inFile.read((char*)mbuffer, sizeof(mbuffer));
     
            unsigned char buffer[16] = "";
     
            for ( size_t i = 0; i < sizeof(mbuffer); i++ )
            {
                buffer[i] = mbuffer[i];
            }
     
            pAESMod->RijndaelCrypt(buffer, ukey, 0);
     
            outFile.write((const char*)buffer, sizeof(buffer));
        }
     
        outFile.close();
        inFile.close();
    };
    PS : le code entre /* */ pourrait être une alternative .. qui ne fonctionne pas .. rajoute plus de caractère et fausse d'autant plus le résultat.

  2. #2
    Nouveau membre du Club
    Inscrit en
    Juillet 2009
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 35
    Points : 30
    Points
    30
    Par défaut
    Je pense que si ton algo nécessite des bloc de 16 char, il faut lui envoyer 16 char...

    A partir de là, voilà la solution que j'imagine :
    Il faut établir une convention pour les octets de remplissage. Ensuite, il faut faire un traitement au moment du décodage pour supprimer ces octets à la fin.

  3. #3
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    AES-128 traite des blocs de 16 octets. Si tes blocs ne font pas 16 octets (le dernier bloc surtout), ce n'est pas le problème d'AES mais c'est une convention à établir entre l'émetteur et le récepteur.

    Ici, plusieurs stratégies de padding avec pour chacune, leurs avantages, leurs inconvénients et leur applicabilité (suivant le message transporté) : http://www.di-mgt.com.au/cryptopad.html
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2011
    Messages : 10
    Points : 9
    Points
    9
    Par défaut
    Merci beaucoup pour ces informations

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

Discussions similaires

  1. Chargement fichier texte bloc par bloc [VB.NET]
    Par kevin01330 dans le forum Général Dotnet
    Réponses: 2
    Dernier message: 23/04/2013, 09h08
  2. Réponses: 8
    Dernier message: 30/07/2012, 10h14
  3. Problème lecture écriture par bloc dans un fichier
    Par scary dans le forum Débuter
    Réponses: 5
    Dernier message: 22/04/2009, 19h28
  4. Réponses: 2
    Dernier message: 20/06/2007, 10h16
  5. Réponses: 20
    Dernier message: 09/02/2006, 09h45

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