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

Langage C++ Discussion :

Tableau de char visible dans un .exe compilé ?


Sujet :

Langage C++

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 136
    Par défaut Tableau de char visible dans un .exe compilé ?
    Salut à tous,

    Je voudrais développer un petit code C++ qui effectue des opérations "sécuritaires": encryption/décryption, vérification du hash d'un fichier, etc.

    Pour ça, j'aurai besoin de coder "en dur" les clefs d'encryption et un "hash" d'un fichier. Soit quelque part dans le code C++ un truc du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    public static char maCleDeCryptage[5] = {'%', 'ù', 'x', '@', '&'};
    La question est: dans quelle mesure est il possible/difficile de "lire" (identifier les bytes qui contiennent la clé) cette clé d'encryption dans le code binaire du .exe compilé ?

    Merci d'avance

  2. #2
    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 : 62
    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
    Par défaut
    Avec un utilitaire genre "strings" (ou string, je ne me rappelle plus) sous unix, ta chaine de caractère sera visible.

    Ce que je fais dans ces cas afin de la masquer un peu plus, c'est une initialisation par programme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    static maCleDeCryptage[5];
    void update_key(void)
    {
       int idx = 0;
       maCleDeCryptage[idx++] = '%';
       maCleDeCryptage[idx++] = 'ù';
       maCleDeCryptage[idx++] = 'x';
       maCleDeCryptage[idx++] = '@';
       maCleDeCryptage[idx++] = '&';
    }
    Au moins, les valeurs d'initialisation de la clé sont "cachées" dans le segment de code du programme.

    Ce que tu peux faire aussi, c'est initialiser avec une clé en dur et ensuite modifier légèrement cette clé par programme.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    static maCleDeCryptage[5] = {'%', 'ù', 'x', '@', '&'};
    void init_key(void)
    {
       int idx = 0;
       for(int idx = 0; idx != sizeof(maCleDeCryptage); idx++)
       {
          maCleDeCryptage[idx] += idx;
       }
    }
    Remarque, ces 2 méthodes permettent de "cacher un peu mieux" la clé mais par contre, cela ne résiste pas trop bien à l'analyse de la mémoire du process (analyse d'un core généré par le programme par exemple)
    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
    .

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    136
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 136
    Par défaut
    Ok merci, ça confirme ce dont je me doutais.
    A+

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

Discussions similaires

  1. Tableau de char[] passé dans une fonction
    Par Joratois dans le forum C
    Réponses: 26
    Dernier message: 07/06/2007, 15h06
  2. [VB6] Compiler une image dans un exe
    Par Vince dans le forum VB 6 et antérieur
    Réponses: 17
    Dernier message: 27/04/2006, 08h27
  3. [VB] COmment compiler une dll dans un exe (zlib.dll)
    Par Khrysby dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 01/11/2005, 12h10
  4. retrouver unesuite de caractères dans un tableau de char
    Par petitours dans le forum C++Builder
    Réponses: 17
    Dernier message: 12/07/2005, 23h43
  5. Réponses: 4
    Dernier message: 10/10/2003, 18h04

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