Heim  >  Artikel  >  Backend-Entwicklung  >  Wie lese ich einen RSA-Schlüssel aus einer Datei für die JWT-Signatur?

Wie lese ich einen RSA-Schlüssel aus einer Datei für die JWT-Signatur?

Linda Hamilton
Linda HamiltonOriginal
2024-11-08 06:53:02307Durchsuche

How to Read an RSA Key from a File for JWT Signing?

So lesen Sie einen RSA-Schlüssel aus einer Datei

Um einen privaten RSA-Schlüssel zum Signieren von JWTs zu verwenden, müssen Sie ihn aus einer Datei extrahieren . Dieser Artikel führt Sie durch den Prozess der Erstellung einer Schlüsselstruktur aus einem vorgenerierten Schlüssel in einer Datei.

Generieren eines RSA-Schlüssels

Der Beispielschlüssel in Die Frage wird mit dem folgenden Befehl generiert:

openssl genrsa 2048 | openssl pkcs8 -topk8 -nocrypt

Lesen des RSA-Schlüssels aus der Datei

Um den Schlüssel aus der Datei zu lesen, können Sie die folgende Kombination verwenden von pem.Decode und x509.ParsePKCS1PrivateKey:

package main

import (
    "crypto/x509"
    "encoding/pem"
    "fmt"
)

func main() {
    // Replace `pemString` with the actual contents of your key file.
    pemString := `-----BEGIN RSA PRIVATE KEY-----
...`

    block, _ := pem.Decode([]byte(pemString))
    key, _ := x509.ParsePKCS1PrivateKey(block.Bytes)
    fmt.Println(key.N) // This prints the key's modulus.
}

Alternative für PKCS#8-codierte Schlüssel

Wenn Sie einen PKCS#8-codierten Schlüssel haben, können Sie ihn lesen es mit x509.ParsePKCS8PrivateKey:

func main() {
    pemString := `-----BEGIN PRIVATE KEY-----
...`

    block, _ := pem.Decode([]byte(pemString))
    parseResult, _ := x509.ParsePKCS8PrivateKey(block.Bytes)
    key := parseResult.(*rsa.PrivateKey)
    fmt.Println(key.N) // This prints the key's modulus.
}

Mit diesen Lösungen können Sie auf einen privaten RSA-Schlüssel aus einer Datei zugreifen und ihn zum Signieren von JWTs oder zum Durchführen anderer kryptografischer Operationen verwenden.

Das obige ist der detaillierte Inhalt vonWie lese ich einen RSA-Schlüssel aus einer Datei für die JWT-Signatur?. 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