Heim >Backend-Entwicklung >Golang >Go-Sprachdokumentanalyse: crypto/hmac. Neue Funktion implementiert HMAC-Hash-Berechnung

Go-Sprachdokumentanalyse: crypto/hmac. Neue Funktion implementiert HMAC-Hash-Berechnung

PHPz
PHPzOriginal
2023-11-04 10:02:26961Durchsuche

Go-Sprachdokumentanalyse: crypto/hmac. Neue Funktion implementiert HMAC-Hash-Berechnung

Go-Sprachdokumentanalyse: crypto/hmac. Neue Funktion implementiert HMAC-Hash-Berechnung, spezifische Codebeispiele sind erforderlich

HMAC (Hash-based Message Authentication Code) ist eine Methode, die eine Hash-Funktion und einen Schlüssel zur Authentifizierung von Nachrichten verwendet Vollständiger Algorithmus. Im crypto/hmac-Paket der Go-Sprache können Sie über die Funktion „Neu“ ganz einfach HMAC-Instanzen erstellen und Hash-Berechnungen durchführen. In diesem Artikel wird die Verwendung der Funktion crypto/hmac.New im Detail analysiert und spezifische Codebeispiele bereitgestellt, um ihre Funktionen und Verwendung zu veranschaulichen.

Werfen wir zunächst einen Blick auf die Funktionssignatur der Funktion crypto/hmac.New:

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

Diese Funktion akzeptiert zwei Parameter: Der erste Parameter ist ein Funktionstyp, der zum Erstellen der angegebenen Hash-Funktionsinstanz verwendet wird. Der zweite Parameter ist ein Byte-Array, das als Schlüssel für die HMAC-Berechnung verwendet wird. Die Funktion gibt einen Wert vom Typ hash.Hash zurück, der gehasht werden kann.

Wie nutzt man also die Funktion crypto/hmac.New? Mit den folgenden Schritten können wir die HMAC-Hash-Berechnung abschließen.

Zuerst müssen wir das Crypto/Hmac-Paket und das Hash-Paket importieren:

import (

"crypto/hmac"
"hash"

)

Dann müssen wir eine Hash-Funktion und einen Schlüssel auswählen, um eine HMAC-Instanz zu erstellen. Hier wählen wir SHA256 als Hash-Funktion und generieren einen zufälligen Schlüssel:

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

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

}

Die Funktion createHMAC im obigen Code akzeptiert zwei Parameter : die Daten und der Schlüssel, die zur Berechnung des HMAC benötigt werden. Innerhalb der Funktion wird die Funktion hmac.New verwendet, um eine SHA256-HMAC-Instanz zu erstellen und mit dem übergebenen Schlüssel zu initialisieren. Schreiben Sie dann die Daten mit der h.Write-Methode in die HMAC-Instanz und erhalten Sie den berechneten Hash-Wert mit der h.Sum(nil)-Methode.

Als nächstes können wir diese createHMAC-Funktion verwenden, um den Hash-Wert von HMAC zu berechnen. Wir können es zum Beispiel so nennen:

func main() {

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

", result)
}

Im obigen Code definieren wir Zeichenfolgendaten und einen Schlüssel. Rufen Sie dann zur Berechnung die Funktion createHMAC auf HMAC-Hash-Wert und verwenden Sie die Funktion fmt.Printf, um das Ergebnis im Hexadezimalformat zu drucken.

Zusammenfassend kann die HMAC-Hash-Berechnung einfach über die Funktion crypto/hmac.New implementiert werden Geben Sie einen Schlüssel ein und rufen Sie die Funktion gemäß den oben genannten Schritten auf, um die Berechnung abzuschließen. In praktischen Anwendungen wird der HMAC-Algorithmus häufig zur Überprüfung der Datenintegrität sowie zur Generierung von Authentifizierungstoken und anderen sicherheitsrelevanten Funktionen verwendet Dieser Artikel wird Ihnen helfen, die Verwendung der Funktion crypto/hmac.New zu verstehen. Erkunden Sie weiterhin die Go-Sprachdokumentation, um die verschiedenen Funktionen und Features dieser Programmiersprache besser anzuwenden

Das obige ist der detaillierte Inhalt vonGo-Sprachdokumentanalyse: crypto/hmac. Neue Funktion implementiert HMAC-Hash-Berechnung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn