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 :

Hachage d'un message avec SHA1


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 211
    Par défaut Hachage d'un message avec SHA1
    Bonjour tout le monde,

    Mon problème est le suivant:

    je cherche à Hacher un message avec SHA1 afin de le signer par la suite avec l'algo RSA, pour procéder voici le bout de code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     string Data = "Salut tout le monde";
     byte[] DataBytes = System.Text.Encoding.UTF8.GetBytes(Data);
     
    //Hasher le message
    SHA1Managed sha1 = new SHA1Managed();
    byte[] hash = sha1.ComputeHash(DataBytes);
     
    string hach = Convert.ToBase64String(hash);
    Avec ce bout de code j'obtiens le hachage suivant en base 64:
    "I4t474liO6H+p8SeDsoIkxmi8b0="

    en essayant de vérifier sous openSSL et en utilisant cette commande:
    $ echo "Salut tout le monde"| openssl dgst -sha1 | openssl enc -base64

    j'obtiens ce résultat:
    "NjFlOWI4Y2NjN2U2MzFkNTQwNTRmZjE1ZGUyYzk2MDczYTM2ZjRjZAo="

    Est ce que quelqu'un sera d'ou vient l'erreur, j'ai pensé à la conversion du string au tableau de bytes du coup j'ai essayé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     
     UnicodeEncoding encoding = new UnicodeEncoding();
     
     byte[] DataBytes = encoding.GetBytes(Data);
     
     byte[] DataBytes = Convert.FromBase64String(Data);
     
     byte[] DataBytes = Encoding.Default.GetBytes(Data);
     
     byte[] DataBytes = System.Text.Encoding.GetEncoding(1252).GetBytes(Data);
     
    byte[] DataBytes = System.Text.Encoding.UTF7.GetBytes(Data);
    ...
    Mais ça me donne pas le résultat souhaité

    Quelqu'un sera m'aider??

    Merci d'avance

  2. #2
    Membre chevronné
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2008
    Messages
    381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Août 2008
    Messages : 381
    Par défaut
    Je viens d'essayer avec ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    byte[] HashValue = new SHA1CryptoServiceProvider().ComputeHash(ASCIIEncoding.UTF8.GetBytes("Salut tout le monde"));
    return Convert.ToBase64String(HashValue);
    Et j'arrive à la même chose que toi.

  3. #3
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Tu es sûr de ton utilisation d'OpenSSL ? Normalement un hash SHA1 fait 160 bits, donc 20 octets. Ce qui est bien le cas du hash que tu génères en C#, mais celui généré par OpenSSL fait 41 octets... donc à mon avis c'est celui là qui est faux.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 211
    Par défaut
    Bonjour tout le monde,

    Merci pour vos réponses rapide,

    Effectivement t'avais raison tomlev la commande d'openssl openssl dgst -sha1 donne un resultat en hexadecimale donc 40 byte et apres l'encodage en base 64 donne un octet de plus. Cela dit j'ai essayé avec cette commande:
    echo "Salut tout le monde"| openssl dgst -sha1 -binary | openssl enc -base6
    et j'ai toujours pas le bon réusltat

    (j'obtiens Yem4zMfmMdVAVP8V3iyWBzo29M0=)

  5. #5
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Par défaut
    Ben y a un progrès, ça fait la bonne taille
    A mon avis tu t'embêtes pour rien... ton utilisation de SHA1Managed est correcte, et le résultat semble juste (vérifié sur des calculateurs en ligne, comme celui là)

    Je sais pas pourquoi OpenSSL donne autre chose, mais c'est sans doute lié à la façon dont tu l'utilises

  6. #6
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Par défaut
    Citation Envoyé par tomlev Voir le message
    Je sais pas pourquoi OpenSSL donne autre chose, mais c'est sans doute lié à la façon dont tu l'utilises
    Au lieu de retourner le buffer de 20 bytes, il doit peut être retourner la chaine de contenu en hexa soit 40 digits, et la dessus une tentative d'encodage doit retourner un résultat sans doute amusant mais pas très utile.

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    211
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 211
    Par défaut
    Citation Envoyé par tomlev Voir le message
    A mon avis tu t'embêtes pour rien... ton utilisation de SHA1Managed est correcte, et le résultat semble juste (vérifié sur des calculateurs en ligne, comme celui là)
    en fait si je vérifie avec OpenSSL c'est pour savoir si mon code sous c# est correct ou pas, pour le site j'ai testé et ça ne me donne pas le même résultat malheureusement (comparer au résultat de mon ComputeHash et aussi de ma commande OpenSSL) ce qui veut quand même dire que mon Hachage sous c#n'est pas correct et je vois vraiment pas d'ou viend l'erreur??!!! je cherche ça fait mnt 2 jours et je suis vraiment bloquée.

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

Discussions similaires

  1. PB multi envoie message avec indy 10 sous D9
    Par korntex5 dans le forum Web & réseau
    Réponses: 1
    Dernier message: 13/07/2005, 14h27
  2. Poster un message avec un CString en parametre
    Par loupdeau dans le forum MFC
    Réponses: 2
    Dernier message: 19/05/2005, 15h02
  3. Message avec un bouton "oui" et "non"
    Par PrinceMaster77 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 26/11/2004, 15h50

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