


hmac.New(h func() hash.Hash, Schlüsselbyte) hash.Hash-Äquivalent in JavaScript
In PHP müssen wir häufig Verschlüsselungsalgorithmen verwenden, um die Datensicherheit zu gewährleisten. HMAC (Hash-based Message Authentication Code) ist ein häufig verwendeter Verschlüsselungsalgorithmus zur Überprüfung der Datenintegrität und Identitätsauthentifizierung. In PHP können wir eine HMAC-Instanz mit der Funktion hmac.New() erstellen, die die Angabe einer Hash-Funktion und eines Schlüssels erfordert. Ebenso können wir in JavaScript äquivalente Methoden verwenden, um die gleiche Funktionalität zu erreichen. In diesem Artikel zeige ich Ihnen, wie Sie mit entsprechenden Methoden in JavaScript eine HMAC-Instanz erstellen und wie Sie Daten zwischen PHP und JavaScript ver- und entschlüsseln.
Frageninhalt
Ich steckte mehrere Tage lang fast in der js-Implementierung von go lang hmac.new fest. Es gab jedoch keinen Erfolg. Ich verwende crypto
、crypto-js
和 stablelib
模块进行实现。问题是,在go lang版本中,hmac
实例可以通过hmac
Instanzerstellung. Zum Beispiel (Codeblock ist korrekt und getestet):
hmacf := hmac.New(func() hash.Hash { return hmac.New(func() hash.Hash { return hmac.New(func() hash.Hash { return hmac.New(sha256.New, []byte(SALT)) }, []byte(path[0])) }, []byte(path[1])) }, []byte(path[2]))
Eigentlich weiß ich auch nicht, wie es funktioniert! Denn in allen Javascript-bezogenen Modulen können Sie keine Werte von hmac
创建 hmac
,并且它们接受确定哈希算法的 string
erhalten.
Vielleicht wäre es besser, in Javascript zu fragen, wie man von hmac
创建hmac
kommt.
Was ist die Lösung?
Wenn die Ausgabe der Go-Version mit der Ausgabe Ihrer Implementierung übereinstimmt, ist Ihre Lösung korrekt.
Workaround
Gemäß der Spezifikation (rfc 2104) verwendet hmac intern Digest-Funktionen, wie z. B. sha256.
Ihre Implementierung wendet jedoch einen HMac an (und ist damit tatsächlich nicht kompatibel), der intern einen anderen HMac anstelle des Digests verwendet, wobei nur der HMac der niedrigsten Ebene intern den regulären Digest verwendet. Dadurch entsteht eine verschachtelte Struktur.
Basierend auf der Spezifikation von regulärem hmac (mit Digest) kann dies auf hmac mit hmac (anstelle von Digest) erweitert werden, das im Go-Code verwendet wird:
hmac(k xor opad, hmac(k xor ipad, text))
s. rfc2104, Abschnitt 2. Definition von hmac
Aufgrund der Unterschiede zur Spezifikation ist es möglicherweise nicht so einfach, eine Javascript-Bibliothek zu finden, die diese Funktionalität sofort unterstützt.
Während die meisten Bibliotheken sicherlich hmac unterstützen, erlauben Sie nur die Angabe von Digests (nicht von hmac), wie z. B. dem Kryptomodul von nodejs crypto.createhmac()
, siehe auch Andere Antworten. Ich glaube nicht, dass dieser Ansatz zur Implementierung von Logik in Go-Code verwendet werden kann.
Wenn die Ansätze der anderen Antworten nicht funktionieren und Sie keine andere Javascript-Bibliothek mit der gewünschten Funktionalität finden, können Sie die Logik selbst in Javascript implementieren, da die Spezifikation von hmac relativ einfach ist (siehe oben).
Der folgende Code ist eine Beispielimplementierung des Kryptomoduls von nodejs:
var crypto = require('crypto') const digest = 'sha256' const blocksize = 64 // block size of the digest // define input parameter var salt = buffer.from('salt') var path = [ buffer.from('alfa'), buffer.from('beta'), buffer.from('gamma') ] var data = buffer.from('data') // calculate hmac var hmac = hmac(data, salt, path) console.log(hmac.tostring('hex')) function hmac(data, salt, path) { // create keylist var keylist = [] keylist.push(salt) keylist = keylist.concat(path) // determine hmac recursively var result = hmac_rec(data, keylist) return result } function hmac_rec(data, keylist) { // adjust key (according to hmac specification) var key = keylist.pop() if (key.length > blocksize) { k = buffer.allocunsafe(blocksize).fill('\x00'); if (keylist.length > 0) { hmac_rec(key, [...keylist]).copy(k) } else { gethash(key).copy(k) } } else if (key.length < blocksize) { k = buffer.allocunsafe(blocksize).fill('\x00'); key.copy(k) } else { k = key } // create 'key xor ipad' and 'key xor opad' (according to hmac specification) var ik = buffer.allocunsafe(blocksize) var ok = buffer.allocunsafe(blocksize) k.copy(ik) k.copy(ok) for (var i = 0; i < ik.length; i++) { ik[i] = 0x36 ^ ik[i] ok[i] = 0x5c ^ ok[i] } // calculate hmac if (keylist.length > 0) { var innerhmac = hmac_rec(buffer.concat([ ik, data ]), [...keylist]) var outerhmac = hmac_rec(buffer.concat([ ok, innerhmac ]), [...keylist]) } else { var innerhmac = gethash(buffer.concat([ik, data])) var outerhmac = gethash(buffer.concat([ok, innerhmac])) } return outerhmac } // calculate sha256 hash function gethash(data){ var hash = crypto.createhash(digest); hash.update(data) return hash.digest() }
Ergebnis:
2e631dcb4289f8256861a833ed985fa945cd714ebe7c3bd4ed4b4072b107b073
Test:
Der folgende Go-Code führt zum gleichen Ergebnis:
package main import ( "crypto/hmac" "crypto/sha256" "encoding/hex" "fmt" "hash" ) func main() { salt := "salt" path := []string{"alfa", "beta", "gamma"} hmacf := hmac.new(func() hash.hash { return hmac.new(func() hash.hash { return hmac.new(func() hash.hash { return hmac.new(sha256.new, []byte(salt)) }, []byte(path[0])) }, []byte(path[1])) }, []byte(path[2])) hmacf.write([]byte("data")) result := hmacf.sum(nil) fmt.println(hex.encodetostring(result)) // 2e631dcb4289f8256861a833ed985fa945cd714ebe7c3bd4ed4b4072b107b073 }
Herausgeber:
Inspiriert von diesem Artikel ist Folgendes hmac_rec()
的更紧凑/高效的实现,它使用常规最后一个迭代步骤的 hmac(这也使得 gethash()
veraltet):
function hmac_rec(data, keyList) { var key = keyList.pop() if (keyList.length > 0) { // adjust key (according to HMAC specification) if (key.length > blockSize) { k = Buffer.allocUnsafe(blockSize).fill('\x00'); hmac_rec(key, [...keyList]).copy(k) } else if (key.length < blockSize) { k = Buffer.allocUnsafe(blockSize).fill('\x00'); key.copy(k) } else { k = key } // create 'key xor ipad' and 'key xor opad' (according to HMAC specification) var ik = Buffer.allocUnsafe(blockSize) var ok = Buffer.allocUnsafe(blockSize) k.copy(ik) k.copy(ok) for (var i = 0; i < ik.length; i++) { ik[i] = 0x36 ^ ik[i] ok[i] = 0x5c ^ ok[i] } // calculate HMAC var innerHMac = hmac_rec(Buffer.concat([ ik, data ]), [...keyList]) var outerHMac = hmac_rec(Buffer.concat([ ok, innerHMac ]), [...keyList]) } else { var outerHMac = crypto.createHmac(digest, key).update(data).digest(); } return outerHMac }
Das obige ist der detaillierte Inhalt vonhmac.New(h func() hash.Hash, Schlüsselbyte) hash.Hash-Äquivalent in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Seit seiner Einführung im Jahr 2009 hat sich Bitcoin zu einem führenden Unternehmen in der Welt der Kryptowährungen entwickelt und sein Preis hat enorme Schwankungen erfahren. Um einen umfassenden historischen Überblick zu bieten, stellt dieser Artikel Bitcoin-Preisdaten von 2009 bis 2025 zusammen und deckt wichtige Marktereignisse, Änderungen der Marktstimmung und wichtige Faktoren ab, die die Preisbewegungen beeinflussen.

1. Klicken Sie zunächst mit der rechten Maustaste auf die leere Stelle der Taskleiste unten in Windows 11 und wählen Sie [Taskleisteneinstellungen]. 2. Suchen Sie rechts in den Taskleisteneinstellungen nach [taskbarcorneroverflow]. 3. Suchen Sie dann darüber nach [Uhr] oder [Uhr] und aktivieren Sie die Funktion. Methode 2: 1. Drücken Sie die Tastenkombination [win+r], um run aufzurufen, geben Sie [regedit] ein und drücken Sie zur Bestätigung die Eingabetaste. 2. Öffnen Sie den Registrierungseditor, suchen Sie darin nach [HKEY_CURRENT_USERControlPanel] und löschen Sie es. 3. Nach dem Löschen starten Sie den Computer neu und Sie werden zur Konfiguration aufgefordert. Wenn Sie zum System zurückkehren, wird die Uhrzeit angezeigt.

Antwort: Die folgenden Community-Foren und Diskussionsgruppen stehen für Fragen zur funktionalen Java-Programmierung zur Verfügung: StackOverflow: Die weltweit größte Q&A-Website zur Programmierung mit einer Community von Experten für funktionale Java-Programmierung. JavaFunctionalProgramming: Ein Community-Forum, das sich auf die funktionale Java-Programmierung konzentriert und Diskussionen zu Konzepten, Sprachfunktionen und Best Practices bietet. Redditr/Functionaljava: Ein Subreddit mit Schwerpunkt auf funktionaler Java-Programmierung, mit Schwerpunkt auf Tools, Bibliotheken und Technologien. Discord: JavaFunctional Programming: Discord-Dienst, der Diskussionen, Code-Sharing und Zusammenarbeit in Echtzeit ermöglicht

Wie verwende ich den Python-Code anderer Leute? Code-Repositories finden: Finden Sie den benötigten Code auf Plattformen wie PyPI und GitHub. Installationscode: Verwenden Sie pip oder klonen Sie das GitHub-Repository zur Installation. Module importieren: Verwenden Sie die Importanweisung in Ihrem Skript, um installierte Module zu importieren. Arbeiten mit Code: Zugriff auf Funktionen und Klassen in Modulen. (Optional) Passen Sie den Code an: Ändern Sie den Code nach Bedarf, um ihn an Ihr Projekt anzupassen.

Was soll ich tun, wenn die Uhrzeit auf meinem Win11-Computer immer falsch ist? Wir alle stellen die Uhrzeit oder den Kalender ein, wenn wir das Win11-System verwenden, aber viele Benutzer fragen sich, dass die Computerzeit immer falsch ist. Was ist also los? Benutzer können direkt auf die Taskleiste unten klicken und dann den Taskbarcorneroverflow suchen, um ihn einzurichten. Auf dieser Website erfahren Sie ausführlich, wie Sie den Zeitfehler auf Win11-Computern anpassen können. So stellen Sie die falsche Uhrzeit auf einem Windows 11-Computer ein. Methode 1: 1. Wir klicken zunächst mit der rechten Maustaste auf die leere Stelle der Taskleiste unten und wählen „Taskleisteneinstellungen“. Methode 2: 1. Drücken Sie die Tastenkombination Win+R, um Ausführen aufzurufen, geben Sie regedit ein und drücken Sie zur Bestätigung die Eingabetaste.

Häufige Ausnahmetypen und ihre Reparaturmaßnahmen bei der Entwicklung von Java-Funktionen Während der Entwicklung von Java-Funktionen können verschiedene Ausnahmen auftreten, die die korrekte Ausführung der Funktion beeinträchtigen. Im Folgenden sind häufige Ausnahmetypen und ihre Reparaturmaßnahmen aufgeführt: 1. NullPointerException Beschreibung: Wird beim Zugriff auf ein Objekt ausgelöst, das nicht initialisiert wurde. Fix: Stellen Sie sicher, dass Sie das Objekt auf Nicht-Null-Werte überprüfen, bevor Sie es verwenden. Beispielcode: try{Stringname=null;System.out.println(name.length());}catch(NullPointerExceptione){

Überlauf ist eine Eigenschaft von CSS, die verwendet wird, um den Anzeigemodus des Elementinhalts zu steuern, wenn er den Container überschreitet. Zu den verfügbaren Werten gehören: sichtbar: Der Inhalt ist sichtbar, der Überlaufcontainer ist ausgeblendet: Der Überlaufinhalt wird abgeschnitten Die Bildlaufleiste wird angezeigt, um den Überlaufinhalt anzuzeigen. Automatisch: Der Browser bestimmt automatisch, ob die Bildlaufleiste angezeigt werden soll. Vererben: Das Überlaufattribut des übergeordneten Elements erben

Als weltbekannte Kurzvideoplattform verfügt Douyin über eine riesige Nutzerbasis und Content-Ersteller. Da die Plattformregeln jedoch ständig aktualisiert und verbessert werden, kann es bei einigen Benutzern zu Kontosperrungen kommen. Dies hat in der Öffentlichkeit Fragen zur Transparenz und Fairness der Plattformverwaltung aufgeworfen. In diesem Artikel geht es um die Sperrung von Douyin-Konten und um die Frage, ob Benutzer nach der Sperrung ihrer Konten Einspruch einlegen können. Es kann viele Gründe für ein Verbot auf der Douyin-Plattform geben, unter anderem illegale Inhalte, Verstöße gegen Plattformbestimmungen, Verletzung der Rechte anderer Personen usw. Um die Ordnung der Plattform und die Interessen der Nutzer aufrechtzuerhalten, hat Douyin eine Reihe von Regeln und Überprüfungsmechanismen eingerichtet. Wenn einige Benutzer gegen die Regeln verstoßen, werden ihre Konten möglicherweise gesperrt. Einige Benutzer stellen jedoch möglicherweise die Gründe für das Verbot in Frage oder sind mit ihnen unzufrieden
