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 :

Chiffrement avec Openssl dans un programme C


Sujet :

C

  1. #1
    Membre du Club Avatar de zentaf
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 122
    Points : 65
    Points
    65
    Par défaut Chiffrement avec Openssl dans un programme C
    Bonjour à tous,

    Je veux faire pareil à ce qui suit dans un programme C en utilisant une API (et non un appel système à Openssl) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $ openssl enc -e -aes-256-cbc -salt -in test.txt -out test.txt.e -k m0nM0tDePasse
    et après :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $ openssl enc -d -aes-256-cbc -salt -in test.txt.e -out test.txt.d -k m0nM0tDePasse
    Je veux utiliser un mot de passe (passé comme char* en paramètre) pour dériver la clef.

    Merci à vous.
    Les hommes sont des caisses fermées dont la clé est l'épreuve..

  2. #2
    Membre du Club Avatar de zentaf
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    Bon, je me suis débrouillé comme un grand après avoir pris un long café avec mon ami google.. je vous mets la solution en cas où vous en avez besoin un jour

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <openssl/rand.h>
    #include <openssl/des.h>
    #include <openssl/evp.h>
     
    //pour générer un sel  
    void generateChallenge(unsigned char *challenge,int chl_size){
     
        int r = 0;
     
        r = RAND_bytes(challenge,chl_size);
     
        if (!r) {
            printf("\nInternal error !\n");
            exit(EXIT_FAILURE);
        }
     
    }
     
    //fonction pour chiffrer/déchiffrer
    int do_crypt (char *infile, char *outfile, int do_encrypt)
        {
     
            /* Allow enough space in output buffer for additional block */
            unsigned char inbuf[1024], outbuf[1024 + EVP_MAX_BLOCK_LENGTH],
                          key[32], iv[32], salt[8];
     
            char *key_data="monMonDePasse";
            int key_data_len = strlen(key_data), nrounds = 1, inlen, outlen;
     
            FILE *in = fopen(infile,"rb");
            FILE *out = fopen(outfile,"wb");
     
            if(do_encrypt){ //if encryption case
                generateChallenge(salt,8);
                fwrite(salt, 1, 8, out);
            }
            else{ //if decryption case
                fread(salt, 1, 8, in);
            }
     
            //derivate key & iv from the supplied password
            EVP_BytesToKey(EVP_aes_256_cbc(), EVP_md5(), salt, (unsigned char*)key_data, key_data_len, nrounds, key, iv);
     
            EVP_CIPHER_CTX ctx;
            EVP_CIPHER_CTX_init(&ctx);
            EVP_CipherInit_ex(&ctx, EVP_aes_256_cbc(), NULL, key, iv, do_encrypt);
     
            for(;;)
            {
                inlen = fread(inbuf, 1, 1024, in);
                if(inlen <= 0) break;
                if(!EVP_CipherUpdate(&ctx, outbuf, &outlen, inbuf, inlen))
                {
                    /* Error */
                    EVP_CIPHER_CTX_cleanup(&ctx);
                    return 0;
                }
                fwrite(outbuf, 1, outlen, out);
            }
     
            if(!EVP_CipherFinal_ex(&ctx, outbuf, &outlen))
            {
                /* Error */
                EVP_CIPHER_CTX_cleanup(&ctx);
                return 0;
            }
     
            fwrite(outbuf, 1, outlen, out);
            EVP_CIPHER_CTX_cleanup(&ctx);
     
            fclose(in);
            fclose(out);
     
            return 1;
        }
     
        int main(){
            do_crypt("test.txt","test.txt.e",1); //encryption
            do_crypt("test.txt.e","test.txt.d",0); //decryption
        }
    Merci à vous.

    ps: Je ne rajoute pas le mot "Salted__" au fichier chiffré comme le fait Openssl en ligne de commande.
    Les hommes sont des caisses fermées dont la clé est l'épreuve..

  3. #3
    Membre expérimenté

    Homme Profil pro
    Collégien
    Inscrit en
    Juillet 2010
    Messages
    548
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Juillet 2010
    Messages : 548
    Points : 1 432
    Points
    1 432
    Par défaut
    Super!!!

    EVP_CIPHER_CTX est une structure dispo dans libc?

  4. #4
    Membre du Club Avatar de zentaf
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    122
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 122
    Points : 65
    Points
    65
    Par défaut
    Citation Envoyé par mith06 Voir le message
    Super!!!

    EVP_CIPHER_CTX est une structure dispo dans libc?
    C'est une structure de la lib openssl. Je t'invite à regarder evp.h ici
    Les hommes sont des caisses fermées dont la clé est l'épreuve..

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 23/10/2012, 17h17
  2. Réponses: 7
    Dernier message: 06/02/2012, 10h04
  3. Réponses: 5
    Dernier message: 02/02/2008, 11h35
  4. Réponses: 4
    Dernier message: 02/05/2007, 16h18
  5. Réponses: 3
    Dernier message: 09/01/2006, 11h26

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