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 サイトの他の関連記事を参照してください。