ホームページ >バックエンド開発 >Golang >Go 1.5 で PKCS8 秘密キーをマーシャルするにはどうすればよいですか?

Go 1.5 で PKCS8 秘密キーをマーシャルするにはどうすればよいですか?

DDD
DDDオリジナル
2024-10-26 16:03:30354ブラウズ

How Can I Marshal PKCS8 Private Keys in Go 1.5?

Go での PKCS8 秘密鍵のマーシャリング

Go 1.5 で PKCS8 秘密鍵をマーシャリングする方法の可用性に関して疑問が生じます。 x509.MarshalPKCS1PrivateKey などの同様の関数が求められています。

カスタム ソリューション

興味深いことに、Go には PKCS8 秘密鍵をマーシャリングするための標準関数がありません。ただし、カスタム ソリューションが以下に提供されています:

<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>

このカスタム関数 rsa2pkcs8 は、Go 1.5 で PKCS8 秘密キーをマーシャリングするために使用できます。

以上がGo 1.5 で PKCS8 秘密キーをマーシャルするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。