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

Python Discussion :

Faire un hash SHA-1


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2010
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2010
    Messages : 41
    Par défaut Faire un hash SHA-1
    Bonjour,
    j'écris actuellement un programme pour lire un fichier de données normalisé.
    Une partie des données du fichier est signé par le procédé détaillé ci-dessous :
    6.1. Génération de signatures
    La génération de signatures de données par l'équipement respectera le schéma de signature avec appendice, défini dans le document de référence PKCS1 avec la fonction de hachage SHA-1:
    Signature = EQT.SK[′00′ || ′01′ || PS || ′00′ || DER[SHA-1(donnéesData)]
    PS = Chaîne d'octets de remplissage de valeur ′FF′ dont la longueur équivaut à 128.
    DER(SHA-1(M)) correspond à l'encodage de l'ID de l'algorithme pour la fonction de hachage et la valeur de hachage, dans une valeur ASN.1 de type DigestInfo (règles d'encodage distinctes):
    ′30′||′21′||′30′||′09′||′06′||′05′||′2B′||′0E′||′03′||′02′||′1A′||′05′||′00′||′04′|| ′14′|| valeur de hachage.
    Que signifie ce charabia ?
    J'aimerais vérifier si mes données sont correcte, je suppose qu'il faut donc que je compare la signature donnée avec une signature que je génère moi-même à l'aide des données du fichier.
    La fonction hashlib.sha1 ne me sors que des signatures longues de 20 bits, alors que celle contenue dans le fichier en fait 128...
    Y-a-t-il une lib qui soit plus appropriée ?

  2. #2
    Membre expérimenté
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    159
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 159
    Par défaut
    Bonsoir,
    Citation Envoyé par Gui310 Voir le message
    La fonction hashlib.sha1 ne me sors que des signatures longues de 20 bits, alors que celle contenue dans le fichier en fait 128...
    Y-a-t-il une lib qui soit plus appropriée ?
    ?
    SHA-1 produit systématiquement un hash de 160 bit (soit 20 octets).

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2010
    Messages
    41
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2010
    Messages : 41
    Par défaut
    Bonjour, effectivement, c'est une erreur, je parle bien d'octets et non de bits.
    J'ai 20 octets et il m'en faut 128.

  4. #4
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Voir PKCS (Public Key Cryptographic Standards) de RSA: http://fr.wikipedia.org/wiki/Public_...phic_Standards

    Et ici: http://www.emc.com/collateral/white-...tandard-wp.pdf

    Bon courage!

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 695
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 695
    Par défaut
    Salut,

    Ce charabia sort de spécifications communautaires que l'on peut trouver ici, voir page 251.

    Les détails sont dans le RFC 3447 publiés par l'IETF.

    Apprendre à lire et à comprendre ce genre de prose n'a rien à voir avec la programmation Python.

    - W
    PS: d'autant que des implémentations existent.
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  6. #6
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Il y a du PKCS1 dans pycrypto (https://pypi.python.org/pypi/pycrypto/2.6.1)

    Sous Windows, pycrypto n'est pas facile à installer. Il vaut mieux prendre un binaire comme ici: http://www.voidspace.org.uk/python/modules.shtml

Discussions similaires

  1. Résultat du hash SHA-1 inexacte
    Par Tiger-222 dans le forum Langage
    Réponses: 4
    Dernier message: 20/12/2010, 21h15
  2. hash sha 256/512 en C
    Par Z-fly dans le forum C
    Réponses: 1
    Dernier message: 20/07/2008, 15h56
  3. Réponses: 2
    Dernier message: 01/05/2008, 16h13
  4. [Processus] Faire un Hash sur un programme en mémoire
    Par KiLVaiDeN dans le forum Windows
    Réponses: 2
    Dernier message: 23/11/2005, 18h40

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