Marshalling privater PKCS8-Schlüssel in Go
Es stellt sich die Frage nach der Verfügbarkeit einer Methode zum Marshallen privater PKCS8-Schlüssel in Go 1.5. Eine ähnliche Funktion, wie z. B. x509.MarshalPKCS1PrivateKey, wird gesucht.
Benutzerdefinierte Lösung
Interessanterweise gibt es in Go keine Standardfunktion zum Marshallen privater PKCS8-Schlüssel. Nachfolgend wird jedoch eine benutzerdefinierte Lösung bereitgestellt:
<code class="go">type pkcs8Key struct { Version int PrivateKeyAlgorithm []asn1.ObjectIdentifier PrivateKey []byte } func rsa2pkcs8(key *rsa.PrivateKey) ([]byte, error) { var pkey pkcs8Key pkey.Version = 0 pkey.PrivateKeyAlgorithm = make([]asn1.ObjectIdentifier, 1) pkey.PrivateKeyAlgorithm[0] = asn1.ObjectIdentifier{1, 2, 840, 113549, 1, 1, 1} pkey.PrivateKey = x509.MarshalPKCS1PrivateKey(key) return asn1.Marshal(pkey) }</code>
Diese benutzerdefinierte Funktion, rsa2pkcs8, kann zum Marshallen privater PKCS8-Schlüssel in Go 1.5 verwendet werden.
Das obige ist der detaillierte Inhalt vonWie kann ich private PKCS8-Schlüssel in Go 1.5 marshalieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!