Maison  >  Article  >  développement back-end  >  Analyse de document en langage Go : crypto/hmac. Une nouvelle fonction implémente le calcul de hachage HMAC

Analyse de document en langage Go : crypto/hmac. Une nouvelle fonction implémente le calcul de hachage HMAC

PHPz
PHPzoriginal
2023-11-04 10:02:26871parcourir

Analyse de document en langage Go : crypto/hmac. Une nouvelle fonction implémente le calcul de hachage HMAC

Analyse de documents en langage Go : crypto/hmac.Nouvelle fonction implémente le calcul de hachage HMAC, des exemples de code spécifiques sont requis

HMAC (Hash-based Message Authentication Code) est une méthode qui utilise une fonction de hachage et une clé pour authentifier les messages Algorithme complet. Dans le package crypto/hmac du langage Go, vous pouvez facilement créer des instances HMAC et effectuer des calculs de hachage via la fonction New. Cet article analysera en détail l'utilisation de la fonction crypto/hmac.New et fournira des exemples de code spécifiques pour illustrer ses fonctions et son utilisation.

Tout d'abord, jetons un coup d'œil à la signature de fonction de la fonction crypto/hmac.New :

func New(h func() hash.Hash, key []byte) hash.Hash

Cette fonction accepte deux paramètres, dont le premier paramètre One est un type de fonction utilisé pour créer l'instance de fonction de hachage spécifiée ; le deuxième paramètre est un tableau d'octets utilisé comme clé pour le calcul HMAC ; La fonction renvoie une valeur de type hash.Hash, qui peut être hachée.

Alors comment utiliser la fonction crypto/hmac.New ? Nous pouvons compléter le calcul du hachage HMAC en suivant les étapes suivantes.

Tout d'abord, nous devons importer le package crypto/hmac et le package de hachage :

import (

"crypto/hmac"
"hash"

)

Ensuite, nous devons choisir une fonction de hachage et une clé pour créer une instance HMAC. Ici, nous choisissons SHA256 comme fonction de hachage et générons une clé aléatoire :

func createHMAC(data []byte, key []byte) []byte {

h := hmac.New(sha256.New, key)
h.Write(data)
return h.Sum(nil)

}

La fonction createHMAC dans le code ci-dessus accepte deux paramètres : les données et la clé nécessaires au calcul du HMAC. À l'intérieur de la fonction, la fonction hmac.New est utilisée pour créer une instance SHA256 HMAC et initialisée à l'aide de la clé transmise. Ensuite, écrivez les données sur l'instance HMAC via la méthode h.Write et obtenez la valeur de hachage calculée à l'aide de la méthode h.Sum(nil).

Ensuite, nous pouvons utiliser cette fonction createHMAC pour calculer la valeur de hachage de HMAC. Par exemple, nous pouvons l'appeler ainsi :

func main() {

data := []byte("Hello, HMAC!")
key := []byte("MySecretKey")
result := createHMAC(data, key)
fmt.Printf("%x

", result)
}

Dans le code ci-dessus, nous définissons une chaîne de données et une clé. Ensuite, appelons la fonction createHMAC pour calculer Valeur de hachage HMAC et utilisez la fonction fmt.Printf pour imprimer le résultat au format hexadécimal.

Pour résumer, le calcul de hachage HMAC peut être facilement implémenté via la fonction crypto/hmac.Nouvelle fonction Il suffit d'en sélectionner une. et appelez la fonction selon les étapes ci-dessus pour terminer le calcul. Dans les applications pratiques, l'algorithme HMAC est souvent utilisé pour vérifier l'intégrité des données, ainsi que pour générer des jetons d'authentification et d'autres fonctions liées à la sécurité

J'espère que cela. Il vous aidera à comprendre l'utilisation de la fonction crypto/hmac.New. Continuez à explorer la documentation du langage Go pour mieux appliquer et comprendre les différentes fonctions et fonctionnalités de ce langage de programmation

.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn